我正在尝试让 jQuery ajaxPrefilter 与以下 JS 代码一起使用。这是我用来调用 ajax 函数的代码。
var $setallow = $(".show");
$setallow.click(function() {
var $allow = $(this).closest("form");
var formData = $allow.serialize();
submitForm(formData);
});
function submitForm(formData) {
$.ajax({
type: "POST",
url: "/schedule_update.php",
data: formData,
dataType: "json",
cache: false,
timeout: 8000,
success: function(data, textStatus, jqXHR) {
},
error: function(data, textStatus, errorThrown) {
}
});
};
这是我要使用的前置过滤器代码。此代码由Expression Engine提供。
$.ajaxPrefilter(function(options, originalOptions, jqXHR) {
var old_xid = EE.XID;
jqXHR.setRequestHeader("X-EEXID", old_xid);
jqXHR.complete(function(xhr) {
var new_xid = xhr.getResponseHeader('X-EEXID');
if (new_xid) {
EE.XID = new_xid;
$('input[name="XID"]').filter('[value="'+old_xid+'"]').val(new_xid);
}
});
});
这是带有表单的 HTML 代码。
<form>
<input type="hidden" name="XID" value="{XID_HASH}" />
<input type="hidden" name="id" value="1" />
<input type="checkbox" name="allow" value="yes" class="show" />
</form>
如何使此预过滤器与我的代码一起使用?一旦我将预过滤器添加到我的 JS 代码的任何部分,表单就不再提交到我的 php 页面来更新数据库。谢谢你提供的所有帮助。