Форум программистов, компьютерный форум, киберфорум
jQuery
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/6: Рейтинг темы: голосов - 6, средняя оценка - 4.50
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313

Формы отправки на почту, когда их много

09.08.2018, 21:04. Показов 1302. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Я делаю для каждой формы отдельный скрипт отправки, чувствую что делаю тупо, можно ли как то сократить данный JS?

В примере 3 формы, они оинаковые просто в трех экземплярах на сайте.


HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
<form  method="post" action="javascript:void(0);" onsubmit="send_form1();"  class="calc_form cf1">
    <a class="close"></a>
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form> 
 
<form  method="post" action="javascript:void(0);" onsubmit="send_form2();"  class="calc_form cf2">
    <a class="close"></a>
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form> 
 
<form  method="post" action="javascript:void(0);" onsubmit="send_form3();"  class="calc_form cf3">
    <a class="close"></a>
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
function send_form1() {
    var msg = $(".cf1").serialize();
    $.ajax({
        type: "POST",
        url: "send_form.php",
        data: msg,
        success: function(data) {
            alert("Сообщение отправлено");
            setTimeout(function() {
                $(".feedback_form_bg").fadeOut();
            }, 1000);
        },
        error: function(xhr, str) {
            alert("Возникла ошибка!");
            setTimeout(function() { $(".feedback_form_bg").fadeOut(); }, 1000);
        }
    });
}
function send_form2() {
    var msg = $(".cf2").serialize();
    $.ajax({
        type: "POST",
        url: "send_form.php",
        data: msg,
        success: function(data) {
            alert("Сообщение отправлено");
            setTimeout(function() {
                $(".feedback_form_bg").fadeOut();
            }, 1000);
        },
        error: function(xhr, str) {
            alert("Возникла ошибка!");
            setTimeout(function() { $(".feedback_form_bg").fadeOut(); }, 1000);
        }
    });
}
function send_form3() {
    var msg = $(".cf3").serialize();
    $.ajax({
        type: "POST",
        url: "send_form.php",
        data: msg,
        success: function(data) {
            alert("Сообщение отправлено");
            setTimeout(function() {
                $(".feedback_form_bg").fadeOut();
            }, 1000);
        },
        error: function(xhr, str) {
            alert("Возникла ошибка!");
            setTimeout(function() { $(".feedback_form_bg").fadeOut(); }, 1000);
        }
    });
}
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
09.08.2018, 21:04
Ответы с готовыми решениями:

Настройка формы отправки на почту
Тут попросили сделать landing page, но не в тему вёрстки добавили - необходимо настроить форму отправки на почту, этому можно где то быстро...

Php для отправки формы на почту
напишите плиз код с пояснениями пример надо пользователю заполнить форму: 1.выбрать шкаф (радио кнопка) 2. ввести свой номер...

Скрипт для формы отправки сообщений на почту
Сделал форму отправки сообщений через Ajax. Форма работает, отправляет, проблема в том, что если даже все поля будут пустые, все равно...

12
1030 / 682 / 297
Регистрация: 04.04.2013
Сообщений: 2,751
09.08.2018, 21:46
Цитата Сообщение от Mailo Посмотреть сообщение
В примере 3 формы, они оинаковые просто в трех экземплярах на сайте.
Вам нужно понимать с какой именно формы пришла заявка?
0
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
10.08.2018, 01:27  [ТС]
Нет, просто сократить js и будет плюсом, если всё это будет отрабатывать по одному классу.
0
1030 / 682 / 297
Регистрация: 04.04.2013
Сообщений: 2,751
10.08.2018, 13:44
Mailo, оставьте у каждой формы одинаковый onsubmit="send_form" и соответственно одной функцией в jquery и обрабатывайте это. С какой целью вы дублируете функции для обработки одинаковых форм?
0
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
10.08.2018, 17:45  [ТС]
Я так и делал первоначально, но в этом случае срабатывала только первая форма, а остальные дублировали её в том случае, если она была заполнена. Т.е. если вводить в первую форму всё ок придёт, а если в любую последующую почему то приходит пустое письмо либо то что было введено в первую форму.
0
18 / 16 / 3
Регистрация: 30.09.2017
Сообщений: 63
11.08.2018, 02:09
На всех 3-х
JavaScript
1
onsubmit="send_form();"
Функция
JavaScript
1
2
function send_form() {
    var msg = $(this).serialize();
И дальше всё также по тексту

---

Или красивей
onsubmit убрать совсем
JavaScript
1
2
3
4
$('form.calc_form').submit(function() {
    var msg = $(this).serialize();
    //вся остальная функция
});
1
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
11.08.2018, 20:31  [ТС]
Татьяна5, оба варианта не рабочие.
1
18 / 16 / 3
Регистрация: 30.09.2017
Сообщений: 63
11.08.2018, 22:05
Mailo, не, оба рабочие
Второй https://jsfiddle.net/bxvse04r/1/ (скрипт не в onload, просто так в подвале)

Добавлено через 5 минут
Вы как именно делаете? Что у вас вышло в итоге? (html/js)
0
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
12.08.2018, 00:49  [ТС]
В первом сообщении абсолютно весь html/js относящийся к проблеме, то что вы порекомендовали мне поменять я протестил + вот php для отправки писем:

PHP
1
2
3
4
5
6
7
8
9
<?
$fio= $_POST['name'];
$phone= $_POST['tel'];
$emailTo = 'mail@test.ru';
$body = "$fio \n\n$phone";
$headers = "Content-Type: text/plain; charset=utf-8\r\n".'From: MySite <'.$emailTo.'>' . "\r\n" . 'Reply-To: ' . $emailTo;
mail($emailTo, $fio, $body, $headers);
$emailSent = true;
?>
0
18 / 16 / 3
Регистрация: 30.09.2017
Сообщений: 63
12.08.2018, 00:52
php здесь не причём
Какой итоговый html/js у вас вышел с моими советами? Который у вас перестал работать
1
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
12.08.2018, 11:57  [ТС]
php здесь не может быть не причём т.к. я по итогам поступления или не поступления пустых/заполненных писем сужу об успехе.

Вот итоговый код - ваш первый способ. Письма отправляются, но приходят пустыми.
0
18 / 16 / 3
Регистрация: 30.09.2017
Сообщений: 63
12.08.2018, 12:13
Лучший ответ Сообщение было отмечено Mailo как решение

Решение

1. У вас сначала идёт скрипт, потом подключается jQuery. Поменяйте местами
2. Функция send_form записана 3 раза. Зачем? Уберите 2 лишних

И поправлю чуть первый способ:
HTML5
1
onsubmit="send_form(this);"
JavaScript
1
2
function send_form(obj) {
    var msg = $(obj).serialize();
Добавлено через 1 минуту
Цитата Сообщение от Mailo Посмотреть сообщение
php здесь не может быть не причём
И всё-таки он не при чём
1
 Аватар для Mailo
178 / 226 / 31
Регистрация: 18.02.2010
Сообщений: 2,313
12.08.2018, 12:44  [ТС]
Всё отлично работает спасибо, итоговый рабочий вариант:

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<form  method="post" action="javascript:void(0);" onsubmit="send_form(this);"  class="calc_form cf1">
    <a class="close"></a>
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form> 
        
        <form  method="post" action="javascript:void(0);" onsubmit="send_form(this);"  class="calc_form cf2">
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form>
    
        <form method="post" action="javascript:void(0);" onsubmit="send_form(this);"  class="calc_form cf3">
            <span>Рассчитать стоимость</span>
            <input class="cf_input" type="text" name="name" placeholder="Имя">
            <input class="cf_input phone" type="text" pattern="+7 ([0-9]{3}) [0-9]{3}-[0-9]{2}-[0-9]{2}" name="tel" placeholder="Телефон">
            <input class="cf_submit" type="submit" value="Отправить">
        </form>
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<script src="https://code.jquery.com/jquery.min.js"></script>
<script>
function send_form(obj) {
    var msg = $(obj).serialize();
    $.ajax({
        type: "POST",
        url: "send_form.php",
        data: msg,
        success: function(data) {
            alert("Сообщение отправлено");
            setTimeout(function() {
                $(".feedback_form_bg").fadeOut();
            }, 1000);
        },
        error: function(xhr, str) {
            alert("Возникла ошибка!");
            setTimeout(function() { $(".feedback_form_bg").fadeOut(); }, 1000);
        }
    });
}
</script>
+ файлик send_form.php в корне сайта
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.08.2018, 12:44
Помогаю со студенческими работами здесь

Скрипт для отправки данных из формы на почту
Здравствуйте, подскажите пожалуйста новичку скрипт для отправки данных из формы на почту info@imperiacoins.esy.es Вот html код...

Скрипт для отправки данных из формы на почту
Доброго времени суток.Первый раз пробую прикрутить форму для отправки данных на мэил и столкнулся с такой проблемой..Не приходят данные на...

Функционирование формы отправки заявки на почту для сайта
В интернете много разных таких форм, но многие не работают другие не понятны, можете помочь с кодом, чтобы все что заполнялось отправлялось...

Php для отправки email формы на мою почту
&lt;div id=&quot;mc_embed_signup&quot; class=&quot;lefts&quot;&gt; ...

Скрипт отправки нескольких файлов из формы с сайта на почту
Как изменить скрипт, чтобы он отправлял несколько выбранных файлов из формы сайта на почту? Есть скрипт отправки одного файла. При выборе...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru