加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

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

发布时间:2020-12-16 00:20:48 所属栏目:百科 来源:网络整理
导读:我们来看这样一段代码: $(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; ............................. }); )
我们来看这样一段代码:

$(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了。

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读