ajax无法即时存入数据,解决使用Ajax方法时,无法将回调的数据存储到全局变量中使用...

我们使用$.ajax时,有时候会需要把从后台获取到的数据存储在全局变量中,方便以后进行调用。

例如:

var i=0;

$(function () {

$.ajax({

url: "/web/home/GetMenusList",

type: "POST",

success: function (data) { //例如data为1

i=data

}

});

console.info(i);

});

这时候打印出来的数据其实还是0,那么这明显不符合我们需求,要解决这个问题首先我们要看一下Ajax同步和异步的功能区别

ajax请求(async:false|true)加载同步与异步的功能区别

1、异步情况:ajax单独开启一个请求,ajax请求未完成即window._code未被赋值时,外部先调用window._code,因为值为空undefined;

2、同步情况:ajax请求完成后(success或error等),window._code被赋值,后续外部操作才可以调用。

由此可以得出结论,如果我们要实现文章开头的需求,需要将Ajax的异步关闭,调用方法async: false

例如:

var i=0;

$(function () {

$.ajax({

url: "/web/home/GetMenusList",

type: "POST",

async: false,//关闭异步加载

success: function (data) { //例如data为1

i=data

}

});

console.info(i);

});

这时候打印出来的i值就是1了

注:使用Ajax进行动态添加HTML元素内容,如果添加的元素中包含绑定的事件,在使用append时必须使用Ajax的同步加载功能,如无绑定事件,则使用异步加载即可

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值