Перейти к содержанию

Рекомендуемые сообщения

Добрый день. Подскажите если не сложно, форма обратной связи, задача сделать что бы корректно работала на всех устройствах, но есть проблемы с safari и експлоером старым

 

 

Есть скрипт который проверяет заполненность поля с required

function fnCheckFields(form_obj){
    var error_msg = "Пожалуйста, заполните все обязательные поля.";
    var is_error = false;
    for (var i = 0; form_obj_elem = form_obj.elements[i]; i++)
        if (form_obj_elem.type  "input" || form_obj_elem.type  "text")
            if (form_obj_elem.getAttribute("required") && !form_obj_elem.value)
                is_error = true;
    if (is_error) alert(error_msg);
    return !is_error;
}

 

И есть скрипт который отсылает данные к обработчику

 

$(document).ready(function() {

    $("#form").submit(function() {
        $.ajax({
            type: "POST",
            url: "forms/callback/mail.php",
            data: $(this).serialize()
        }).done(function() {
            $(this).find("input").val("");
            alert("Спасибо за заявку! Скоро мы вам перезвоним.");
            $("#form").trigger("reset");
                        $.fn.colorbox.close();
        });
        return false;
    });
    
});

 

Как сделать что если первый скрипт проверил и поля заполнены то запускать второй скрипт, а если не заполнено то выводить сообщение "Пожалуйста, заполните все обязательные поля."

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

но победить можно? за $

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

alexb, попробуйте так:

 

Скрытый текст

function fnCheckFields(form_obj){
    var error_msg = "Пожалуйста, заполните все обязательные поля.";
    var is_error = false;
    for (var i = 0; form_obj_elem = form_obj.elements[i]; i++)
        if (form_obj_elem.type  "input" || form_obj_elem.type  "text")
            if (form_obj_elem.getAttribute("required") && !form_obj_elem.value)
                is_error = true;
    if (is_error) alert(error_msg);
    return !is_error;
}


 
$(document).ready(function() {
    $("#form").submit(function() {
		var obj = $(this).serializeArray();		
		
		if (fnCheckFields(obj)) {
			$.ajax({
				type: "POST",
				url: "forms/callback/mail.php",
				data: $(this).serialize()
			}).done(function() {
				$(this).find("input").val("");
				alert("Спасибо за заявку! Скоро мы вам перезвоним.");
				$("#form").trigger("reset");
				$.fn.colorbox.close();
			});
		}
		
        return false;
    });
});

 

 

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты
В 09.05.2017 в 17:41, Designer сказал:

alexb, попробуйте так:

 

  Скрыть контент


function fnCheckFields(form_obj){
    var error_msg = "Пожалуйста, заполните все обязательные поля.";
    var is_error = false;
    for (var i = 0; form_obj_elem = form_obj.elements[i]; i++)
        if (form_obj_elem.type  "input" || form_obj_elem.type  "text")
            if (form_obj_elem.getAttribute("required") && !form_obj_elem.value)
                is_error = true;
    if (is_error) alert(error_msg);
    return !is_error;
}


 
$(document).ready(function() {
    $("#form").submit(function() {
		var obj = $(this).serializeArray();		
		
		if (fnCheckFields(obj)) {
			$.ajax({
				type: "POST",
				url: "forms/callback/mail.php",
				data: $(this).serialize()
			}).done(function() {
				$(this).find("input").val("");
				alert("Спасибо за заявку! Скоро мы вам перезвоним.");
				$("#form").trigger("reset");
				$.fn.colorbox.close();
			});
		}
		
        return false;
    });
});

 

 

 

К сожалению не срабатывает скрипт отправки, не отправляет и не выводит сообщение "Спасибо за заявку! Скоро мы с вами свяжемся."

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Спасибо, нашел человека кто взялся помочь.

Поделиться сообщением


Ссылка на сообщение
Поделиться на другие сайты

Для публикации сообщений создайте учётную запись или авторизуйтесь

Вы должны быть пользователем, чтобы оставить комментарий

Создать учетную запись

Зарегистрируйте новую учётную запись в нашем сообществе. Это очень просто!

Регистрация нового пользователя

Войти

Уже есть аккаунт? Войти в систему.

Войти

  • Последние посетители   0 пользователей онлайн

    Ни одного зарегистрированного пользователя не просматривает данную страницу

×

Важная информация

На нашем сайте используются файлы cookie и происходит обработка некоторых персональных данных пользователей, чтобы улучшить пользовательский интерфейс. Чтобы узнать для чего и какие персональные данные мы обрабатываем перейдите по ссылке. Если Вы нажмете «Я даю согласие», это означает, что Вы понимаете и принимаете все условия, указанные в этом Уведомлении о Конфиденциальности.