微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

javascript-$.ajaxComplete和$.ajaxError的正确用法?

我在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;
    });​

我应该怎么做?

http://jsfiddle.net/D7qgd/

解决方法:

首先,您要查找的单词已“弃用”.据我所知,成功和错误属性绝对不会被弃用.您可以(并且应该根据您的情况)继续使用它们.

您尝试使用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] 举报,一经查实,本站将立刻删除。

相关推荐