Jquery高手请进 20
varxx="11";$.ajax({url:domain(...),processData:false,cache:false,dataType:"json",succ...
var xx="11";
$.ajax( {url : domain(...),
processData : false,
cache : false,
dataType : "json",
success : function(obj) {
alert(obj);//加入这里obj的返回的值是"100"
c: xx=obj;
}});
a: alert(xx);
b:window.parent.$("#fid").val(xx);//为父窗口的一个输入域赋值。
上面只是一部分代码。我想请教各位的是
当我去掉a处的代码时候xx的值始终是11,父窗口的值是11,c处的代码赋值不成功,当有a处代码的时候alert弹出是11但是父窗口的值却能成功赋值.
请问下路过的各位大侠我的代码出错在那里。先谢谢了 展开
$.ajax( {url : domain(...),
processData : false,
cache : false,
dataType : "json",
success : function(obj) {
alert(obj);//加入这里obj的返回的值是"100"
c: xx=obj;
}});
a: alert(xx);
b:window.parent.$("#fid").val(xx);//为父窗口的一个输入域赋值。
上面只是一部分代码。我想请教各位的是
当我去掉a处的代码时候xx的值始终是11,父窗口的值是11,c处的代码赋值不成功,当有a处代码的时候alert弹出是11但是父窗口的值却能成功赋值.
请问下路过的各位大侠我的代码出错在那里。先谢谢了 展开
4个回答
2011-03-21
展开全部
设置$.ajax()的async为false,你现在用的ajax方式,默认是异步请求
展开全部
把success换成complete试试
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你出错的原因在于:
因为ajax是异步的,意思就是当你执行请求后success里面的内容并没有马上执行,而是在等待服务器端返回结果。
接着马上执行的是a,b
等服务器有结果返回时才会执行c。
为什么加了a,b就会正常?
因为加了a以后,实际上程序在这里受到阻断,处于暂停状态,但是ajax异步请求是不会停止的。就是在你关闭alert弹出框的那段时间c执行了,所以等你关闭以后,b的值实际上是经过c处理了。也就是所谓的正常了。
-----实际上,你要等待c处理完以后再用xx的值,把bc放在success外面无论如何是不安全的。
因为ajax是异步的,意思就是当你执行请求后success里面的内容并没有马上执行,而是在等待服务器端返回结果。
接着马上执行的是a,b
等服务器有结果返回时才会执行c。
为什么加了a,b就会正常?
因为加了a以后,实际上程序在这里受到阻断,处于暂停状态,但是ajax异步请求是不会停止的。就是在你关闭alert弹出框的那段时间c执行了,所以等你关闭以后,b的值实际上是经过c处理了。也就是所谓的正常了。
-----实际上,你要等待c处理完以后再用xx的值,把bc放在success外面无论如何是不安全的。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
你要的结果就是让xx重新赋值以后在执行b对吧!把b放到c下面就行啦
希望对你有所帮助 对啦 楼上的补充是正解
希望对你有所帮助 对啦 楼上的补充是正解
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询