Работа в submitHandler должен представить форму, не регистрировать отправки формы обработчик события.
Выдавать submitHandler, когда в вашем случае инициируется событие отправки формы, вместо того, чтобы отправлять форму, которую вы регистрировали обработчик отправки, поэтому, когда событие отправки формы запускается в первый раз, форма не отправляется. когда он запускается во второй раз, сначала событие отправки обрабатывается валидатором, а затем обработчик, который вы зарегистрировали, запускает запрос ajax.
В submitHandler вы просто должны отправить Аякса запрос нет необходимости регистрировать обработчик событий
$("#add-form").validate({
submitHandler: function (form) {
// setup some local variables
var $form = $(form);
// let's select and cache all the fields
var $inputs = $form.find("input, select, button, textarea");
// serialize the data in the form
var serializedData = $form.serialize();
// let's disable the inputs for the duration of the ajax request
$inputs.prop("disabled", true);
// fire off the request to /form.php
request = $.ajax({
url: "forms.php",
type: "post",
data: serializedData
});
// callback handler that will be called on success
request.done(function (response, textStatus, jqXHR) {
// log a message to the console
console.log("Hooray, it worked!");
alert("success awesome");
$('#add--response').html('<div class="alert alert-success"><button type="button" class="close" data-dismiss="alert">×</button><strong>Well done!</strong> You successfully read this important alert message.</div>');
});
// callback handler that will be called on failure
request.fail(function (jqXHR, textStatus, errorThrown) {
// log the error to the console
console.error(
"The following error occured: " + textStatus, errorThrown);
});
// callback handler that will be called regardless
// if the request failed or succeeded
request.always(function() {
// reenable the inputs
$inputs.prop("disabled", false);
});
}
});
Что такое '** js с другой страницы **' должно быть? Прошу показать достаточно кода, чтобы сделать краткую демонстрацию проблемы. Ваш OP не должен полагаться на внешние ссылки, чтобы показать весь соответствующий код. Плагин jQuery Validate требует только _one_ click, если вы ошибочно не завернули '.validate()' внутри обработчика 'click' или' submit'. И в вашем случае вы ошибочно завернули обработчик 'submit' внутри плагина по умолчанию' submitHandler'. Поскольку обратный вызов 'submitHandler' модуля плагина уже фиксирует событие отправки, ваш закрытый обработчик' submit' является избыточным. – Sparky