解決ajax異步傳輸數據,return返回為undefined的問題


 

  1. function GetUserInfo(tp) { 
  2.     var username; 
  3.     $.ajax({ 
  4.         type: "POST", 
  5.         cache: false, 
  6.         data: "type=exlogin&tp=" + tp, 
  7.         url: "Handle/OpeartionHandler.ashx", 
  8.         success: function(userinfo) { 
  9.             username = userinfo; 
  10.         }, error: function(data) { 
  11.             username = ""; 
  12.         } 
  13.     }); 
  14.     return username; 
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. function GetUserInfo(tp) { 
  2.     var username; 
  3.     $.ajax({ 
  4.         type: "POST", 
  5.         cache: false, 
  6.         data: "type=exlogin&tp=" + tp, 
  7.         async: false, 
  8.         url: "Handle/OpeartionHandler.ashx", 
  9.         success: function(userinfo) { 
  10.             username = userinfo; 
  11.         }, error: function(data) { 
  12.             username = ""; 
  13.         } 
  14.     }); 
  15.     return username; 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM