ajax获取到后台值后return不起作用,分下如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
function GetUserInfo(tp) {
var username;
$.ajax({
type: "POST" ,
cache: false ,
data: "type=exlogin&tp=" + tp,
url: "Handle/OpeartionHandler.ashx" ,
success: function (userinfo) {
username = userinfo;
}, error: function (data) {
username = "" ;
}
});
return username;
} |
对于此方法调用之后会一直返回undefined,原因是Jquery的ajax是异步的,所以大多时候没执行完AJAX就return htmlcontent了,所以会一直返回undefined,
解决方法:添加async: false,即修改此方法为同步
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
|
function GetUserInfo(tp) {
var username;
$.ajax({
type: "POST" ,
cache: false ,
data: "type=exlogin&tp=" + tp,
async: false ,
url: "Handle/OpeartionHandler.ashx" ,
success: function (userinfo) {
username = userinfo;
}, error: function (data) {
username = "" ;
}
});
return username;
} |
以上方法,可以实现,获取到return的值,但是不推荐使用。
推荐用传入函数的方式获取 ajax return的值。
http://www.jb51.net/article/28597.htm
本文转自许琴 51CTO博客,原文链接:http://blog.51cto.com/xuqin/1548434,如需转载请自行联系原作者