Ajax回调数据赋值给变量的问题

Ajax回调数据赋值给变量的问题

写这篇文章是因为我上面Ztree的文章引发的我对js的研究,不明白的可以先看看上面Ztree的返回数据那块,因为是同一个小例子,上篇是所有的代码,上图

在这里插入图片描述
我声明全局变量tree,在Success回调函数里把回调的数据赋值给变量,我当时想着根据编程习惯做法也都是这,但是问题出现了,我先简单说下Console.info这个方法是在控制台打印数据,因为alert返回数据的时候如果是json一些数据的时候,你是alert不出来实际数据的,这个方法是试用火狐的,IE是不行的好像,这个不讨论这个,火狐上装的是Firebug插件,打印的结果是,如图:
在这里插入图片描述
打印的结果是没有的,接着我按下面这种方法如下图 ,也就是我把打印放在回调函数里是可以打印出来数据的,
在这里插入图片描述
这时候我疑问的是为什么回调过来的数据不能赋值给全局变量,紧接着我看了Jquery 的API,发现了同步的方法,也就是如下图:
在这里插入图片描述
async: false在ajax里加上是可以的,当然除了这个方法之外还可以把 . f n . z T r e e . i n i t ( .fn.zTree.init( .fn.zTree.init(("#treeDemo"), setting, tree);这段代码写在回调函数里也是可以实现树形菜单的,但是我还是纠结为什么回调的数据部能赋值给变量,接下来我有做了另一个实验,如下图:
在这里插入图片描述
我在回调里面打印了下,又在外面打印了下,结果如下图:
在这里插入图片描述
先打印出来的是下面的,问题比较明了了,虽然我先写的ajax但是还是先执行的下面的代码,所以那个变量tree是打印不出来的,而在回调里面的是后来赋值的所以能打印出来,总结下那就是按照我一开始的写法异步请求不能将返回值传给全局变量的,因为JS只管执行当前代码,顺序执行。发送请求了,那是请求响应的事,它不管这些,只管继续执行在它面前的代码,所以是得不到变量赋值的,要想传给变量可以使用同步也就是async: false,但是同步是要同步请求将锁住浏览器,用户其它操作必须等待请求完成才可以执行。如果想要赋值给Ztree的树形菜单数据的话,我最后还是选择了在回调函数里进行初始化,想在深入了解的大家可以看下JS异步原理,这里我就不多讨论了,大家可以看看Ztree那篇的代码,好了,结束。

出处: http://www.cnblogs.com/liunianmoshi/
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是作者坚持原创和持续写作的最大动力!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值