Ajax修改全局变量问题解决方法(Zepto版)
前两天项目遇到一个用ajax修改全局变量的案例,一开始无法给这个全局变量修改赋值,在网上查了一下,解决如下:
修改前:
var word=1; $.ajax({ url:"myJSON.json", type:"get", dataType:"json", success:function(data){ word=2; } }); alert(word);
结果:弹出1;
原因:js是单线程的语言,而ajax是异步加载的,可以这么理解,上面的代码中,先运行完了alert,才运行ajax里的赋值,因此弹出的word的值是1
修改后:
var word=1; $.ajax({ async:false, url:"myJSON.json", type:"get", dataType:"json", success:function(data){ word=2; } }); alert(word);
结果:弹出2
原因:代码中增加async:false,将ajax修改为同步加载,那么整个代码就按照先后顺序加载完成,因此弹出的word的值是2