利用jquery的$.Deferred方法在一个函数内获取另一个函数的返回值

博客介绍了JavaScript中方法执行顺序的使用场景,即方法B需在方法A执行完成后执行,因方法B会用到方法A的变量,还提到引入jQuery1.5以后版本可解决此问题,同时也能满足同步请求需求。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用场景:方法B需要方法A执行完成之后再执行,比如方法B中有用到方法A的变量;(需要引入jQuery1.5以后的版本)

function A(){

    var deffered = new $.Deferred();//

    $.ajax({

            url:"/mktgPlan/getCfgCpmpComponent",

            cache: false,

            dataType:'json',

            type : 'post',

            success:function(data){

                deffered.resolve (data);//

            }

    })
    return deffered;//

}

function B(){
    var def = A();//
    def.then(function(data){//⑤  data就是②返回的值
       console.log(data)
    });
}

此方法也一并解决了需要同步请求的需求

$.ajaxSetup({ 
    async : false 
});

转载于:https://www.cnblogs.com/zhb7769/p/10882277.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值