ajax回调函数执行顺序带来的同步异步问题
2012-02-20 17:29
666 查看
我们来看这样一段代码:
$(function(){
var a =0;
$.getJSON(
"student_toadd",
{stunum:10},
function(json,status)
{
$.each(json,function(i){
$('#stuDiv').append("<div>学生学号:"+json[i].num+"</div>" );
}
.........................................
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},
success:function(json,status)
{
$.each(json,function(i){
$('#stuDiv').append("<div>学生学号:"+json[i].num+"</div>" );
}
.........................................
a = 10;
);
});
alert(a);
这表示将$.ajax拿到返回值后,在执行后面的js。这样a就是10了。这样有什么启发呢?比如我们需要等到返回值在页面绘制一些元素,如果是异步的话,有可能绘制出来的东西是空的。
$(function(){
var a =0;
$.getJSON(
"student_toadd",
{stunum:10},
function(json,status)
{
$.each(json,function(i){
$('#stuDiv').append("<div>学生学号:"+json[i].num+"</div>" );
}
.........................................
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},
success:function(json,status)
{
$.each(json,function(i){
$('#stuDiv').append("<div>学生学号:"+json[i].num+"</div>" );
}
.........................................
a = 10;
);
});
alert(a);
这表示将$.ajax拿到返回值后,在执行后面的js。这样a就是10了。这样有什么启发呢?比如我们需要等到返回值在页面绘制一些元素,如果是异步的话,有可能绘制出来的东西是空的。
相关文章推荐
- ajax回调函数执行顺序带来的同步异步问题
- ajax回调函数执行顺序带来的同步异步问题
- 如何按照顺序执行异步ajax的回调函数
- ajax回调函数执行顺序带来的同步异步问题
- ajax回调函数执行顺序带来的同步异步问题
- jquery中ajax函数执行顺序问题 ---设置同步
- jquery中ajax函数执行顺序问题之如何设置同步
- js中的for循环与异步回调函数执行顺序问题
- ajax回调函数执行顺序带来的同步异步问题
- jquery中ajax函数执行顺序问题之如何设置同步
- js 异步操作,回调函数控制执行顺序
- ajax异步模式下实现等待loading(jQuery同步Ajax带来的UI线程阻塞问题及解决办法)
- JavaScript同步、异步、回调执行顺序之setTimeout面试题分析
- jQuery中ajax方法无法执行回调函数问题
- JavaScript同步、异步、回调执行顺序分析
- JavaScript同步、异步、回调执行顺序之经典闭包setTimeout面试题分析
- JavaScript同步、异步、回调执行顺序之经典闭包(setTimeout面试题分析)
- 前端踩坑小结:多个异步请求在同一个函数里面执行时的同步问题之promise的用法。
- ajax异步执行回调函数内容