我有以下代码:
function submitHandler($link, $modal, close) {
var $form = $modal.find('#main-form');
var $submitBt = $modal.find('.block-footer button:contains("Submit")');
var oSubmit = {
$form: $form,
$modal: $modal,
action: $form.attr('data-action'),
entity: $form.attr('data-entity'),
href: $form.attr('data-href'),
row: $link.attr('data-row'),
$row: $('#row_' + $link.attr('data-row')),
$submitBt: $submitBt
};
if (!$form.valid || $form.valid()) {
$submitBt.disableBt();
$modal.removeBlockMessages()
.blockMessage('Contacting Server, please wait ... ', { type: 'loading' });
$.ajax({
url: oSubmit.href,
dataType: 'json',
type: 'POST',
data: $form.serializeArray()
})
.done(function (json, textStatus, XMLHttpRequest) {
json = json || {};
if (json.success) {
submitSuccessModal(oSubmit, json);
if (close == true) {
$modal.closeModal();
if (oSubmit.action == "Create") {
$('#createLink').prop('disabled', false);
}
}
} else {
submitFailModal(oSubmit, json);
}
})
.fail(function (XMLHttpRequest, textStatus, errorThrown) {
setTimeout(function () {
$modal
.removeBlockMessages()
.blockMessage('Could not contact server, please try again', { type: 'error' });
$submitBt.enableBt();
}, 1000);
return false;
});
};
};
将功能从我的$ .ajax移出到“完成”的功能以及“失败”的另一个功能的最佳方法是什么?我应该将哪些参数传递给这些函数?我想我最困惑的是我应该怎样处理我在代码顶部声明的变量。我是否应该将这些也传递给.done中的外部函数,我会参考其中的一些。
答案 0 :(得分:2)
您现在需要使用的是所谓的匿名函数。您将对匿名函数(没有名称的函数)的引用传递到done
和fail
函数。
也许为了更好地组织代码(或使这些函数与其他代码共享),您需要做的就是为这些函数命名并将它们移到ajax()
调用之外。我们会将它们称为onDone
和onFail
,但您可以将其称为任何有意义的内容。
注意我在没有parathesis的情况下引用它们,因为我指的是函数对象本身,而不是被调用函数的返回值。
function onDone(json, textStatus, XMLHttpRequest) {
json = json || {};
if (json.success) {
submitSuccessModal(oSubmit, json);
if (close == true) {
$modal.closeModal();
if (oSubmit.action == "Create") {
$('#createLink').prop('disabled', false);
}
}
} else {
submitFailModal(oSubmit, json);
}
}
function onFail(XMLHttpRequest, textStatus, errorThrown) {
setTimeout(function () {
$modal
.removeBlockMessages()
.blockMessage('Could not contact server, please try again', { type: 'error' });
$submitBt.enableBt();
}, 1000);
return false;
}
$.ajax({
url: oSubmit.href,
dataType: 'json',
type: 'POST',
data: $form.serializeArray()
})
.done(onDone) //Reference to onDone, without parenthesis
.fail(onFail);
答案 1 :(得分:0)
由于done()
和fail()
已经将匿名函数作为参数,您可以在其他地方简单地声明这些函数,然后按名称引用它们:
var doneFunction = function (json, textStatus, XMLHttpRequest) {
...
};
var failFunction = function (XMLHttpRequest, textStatus, errorThrown) {
...
};
$.ajax({
url: oSubmit.href,
dataType: 'json',
type: 'POST',
data: $form.serializeArray()
})
.done(doneFunction)
.fail(failFunction);
答案 2 :(得分:0)
这个怎么样:
var ajax_functions = {};
ajax_functions.success = function(json, textStatus, XMLHttpRequest) {
// code
};
ajax_functions.error = function(XMLHttpRequest, textStatus, errorThrown) {
// code
};
$.ajax({
url: oSubmit.href,
dataType: 'json',
type: 'POST',
data: $form.serializeArray(),
success: ajax_functions.success,
error: ajax_functions.error
});