浅析jquery ajax异步调用方法中不能给全局变量赋值的原因及解决方法
1个回答
展开全部
本篇文章主要是对jquery
ajax异步调用方法中不能给全局变量赋值的原因及解决方法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
在调用一个jquery的ajax方法时我们有时会需要该方法返回一个值或者给某个全局变量赋值,可是我们发现程序执行完后并没有获取到我们想要的值,这时很有可能是因为你用的是ajax的异步调用async:true(默认情况),如:
代码如下:
function
ManageCommentText(text)
{
var
result
=
text;
$.ajax({
data:
"get",
url:
"GetComments.aspx",
data:
"type=getText&commentText="
+
text,
cache:
false,
async:
false,
success:
function
(data)
{
result
=
data;
}
})
return
result;
以上方法是ajax的同步调用,只有在获取到了data值并赋值给result以后才会返回result完成该方法的调用。若设为async:true,
则会未等到获取data值就已经返回了result。
另一个解决办法就是将你的代码直接写到success方法里。(根据你的业务并不是所有的都可以直接写到success里的)。
注意:如果设定为
async:
false,就失去
ajax异步的优点了哦。
ajax异步调用方法中不能给全局变量赋值的原因及解决方法进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
在调用一个jquery的ajax方法时我们有时会需要该方法返回一个值或者给某个全局变量赋值,可是我们发现程序执行完后并没有获取到我们想要的值,这时很有可能是因为你用的是ajax的异步调用async:true(默认情况),如:
代码如下:
function
ManageCommentText(text)
{
var
result
=
text;
$.ajax({
data:
"get",
url:
"GetComments.aspx",
data:
"type=getText&commentText="
+
text,
cache:
false,
async:
false,
success:
function
(data)
{
result
=
data;
}
})
return
result;
以上方法是ajax的同步调用,只有在获取到了data值并赋值给result以后才会返回result完成该方法的调用。若设为async:true,
则会未等到获取data值就已经返回了result。
另一个解决办法就是将你的代码直接写到success方法里。(根据你的业务并不是所有的都可以直接写到success里的)。
注意:如果设定为
async:
false,就失去
ajax异步的优点了哦。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询