ajax回调函数执行顺序带来的同步异步问题

前端之家收集整理的这篇文章主要介绍了ajax回调函数执行顺序带来的同步异步问题前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我们来看这样一段代码

$(function(){

var a =0;

$.getJSON(

"student_toadd",

{stunum:10},51); font-family:Arial; font-size:14px; line-height:26px"> $.each(status,function(i){

........................

a=10;

.............................

});

)

alert(a);

});

你说说看弹出的a是多少?我说:有可能是10,有可能是0。

为毛?

因为ajax的执行是异步的,有可能回调函数还没有拿到返回值,就弹出a了。

解决办法

var a = 0;

$.ajax({
type:
"get,

dataType:json async: false// 异步为false

url:student_toadd data:{stunum:10},51); font-family:Arial; font-size:14px; line-height:26px"> success:function(data){ a = 10;}

});

alert(a);

这表示,将$.ajax拿到返回值后,在执行后面的js。

这样a就是10了。

猜你在找的Ajax相关文章