我在ajax表单提交中一直使用以下代码段:
$.ajax({
url: "",
data: ilmoittautumisdata,
type: "POST",
success:function(){
});
error:function(){
});
});
但是,我记得我被告知停止使用成功和错误,因为它们已被弃用(?),而改用$.ajaxComplete();.和$.ajaxError();.
但是,阅读文档并没有帮助我,因为我想同时使用它们,这对我没有用.
$('#ilmoittuminen').submit(function(){
var ilmoittautumisdata = $('#ilmoittuminen').serialize();
$.ajax({
//url: "",
data: ilmoittautumisdata,
type: "POST"
});
$.ajaxComplete(
function(){
$('#ilmoittuminen').slideUp();
});
$.ajaxError(
function(){
});
return false;
});
我应该怎么做?
解决方法:
首先,您要查找的单词已“弃用”.据我所知,成功和错误属性绝对不会被弃用.您可以(并且应该根据您的情况)继续使用它们.
您尝试使用ajaxError和ajaxComplete的问题在于它们是作为实例方法实现的,而不是在jQuery对象本身上的静态方法.因此,您需要选择一些元素并在该集合上调用方法.元素本身根本不重要:
$("#someElement").ajaxComplete(function () {
// Do stuff
});
下一个尚未遇到的问题是ajaxError和相关方法注册了全局AJAX事件处理程序.每次调用这些方法之一时,都会向全局集添加一个新的事件处理程序,并且每次触发AJAX事件时,将执行所有已注册的处理程序.
更新(感谢@DCoder)
看起来成功和错误属性自jQuery 1.8起已被弃用.相反,您可以使用jQuery修改的XHR对象的fail,done和always方法.从deferred object继承的任何对象都可以使用以下方法(jqXHR对象是以下方法之一):
$.ajax(ajaxSetupObject).done(function () {
// Handle success
}).error(function () {
// Handle error
});
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。