阮一峰关于deferred 详解

关于jquery中ajax请求的深入了解,deferred可能是jquery中1.5版本以后最重要的方法,你真的理解了吗!

http://www.ruanyifeng.com/blog/2011/08/a_detailed_explanation_of_jquery_deferred_object.html


自己试着封装的ajax

直接上马:

html:

 <button id="btn" οnclick="ajaxBtn(this)"></button>
js代码:

/*
    * @obj 事件对象
    * @url必填
    * @data,type,async beforeSend有默认值
    * @beforeSend ajax发送之前的状态事件;
    * @ajax 形成promise对象 
    * @then 成功与失败的函数
    * */
    jQuery.extend({
        ajaxCode:function (url,data,type,async) {
            var dtd = $.Deferred();
           $.ajax({
                url:url,
                data:data || {},
                type: type || 'GET',
                cache: 'false',
               dataType:dataType || 'json',
                async:async || 'true',
                success: dtd.resolve,
                error: dtd.reject,
            });
            return dtd.promise();
        },
        ajaxCode2:function (url,data,type,async) {
            var dtd = $.Deferred();
           $.ajax({
                url:url,
                data:data || {},
                type: type || 'GET',
                cache: 'false',
               dataType:dataType || 'json',
                async:async || 'true'
            }).then(function(data){
                 dtd.resolve(data);
            }, function(){
                 toastr.error("提交失败", "操作失败");
                 dtd.reject();
            });


            return dtd.promise();
        },
    });





    function ajaxBtn (obj) {
        var  obj =  arguments[0] ;
        $.ajaxCode(obj,url,data,type,async,beforeSend).then(function(data){},function(data){})
    };


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值