快速解決ajax返回值給外部函數(shù)的問題
如下所示:
function validateUser(mya){
var val=mya.name;
val = $.trim(val);
var flag=true;
if(val != ""){
var url1="${pageContext.request.contextPath}/group/getUserCount"
var data1= {"gid":val, time:new Date()};
$.post(url,data1,function(data){
// 1 表示用戶名為空,可以注冊
if(data=="1"){
alert("不能刪除,改組中有用");
flag=false;
}else{
flag=true;
}
})
if(flag==0){ //沒有有用戶
return true;
}else{
alert("改組中含有用戶,不能刪除");
return false;
}
}
}
問題: $.post的回調函數(shù)是在一個閉包中,有自己的作用域,返回值對于外部的函數(shù)不起作用,
可以在外部定義全局變量flag,但是 $.post異步請求,提前返回了flag, flag永遠的默認值,
解決方式: 使用$.ajax,把 異步請求設置為同步請求
其實 ajax功能非常強大,可以直接不用拼接json
$.ajax({
url:url1,
async:false,
data:data1,
success:function(data){
flag=data;
}
以上這篇快速解決ajax返回值給外部函數(shù)的問題就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
基于iframe實現(xiàn)ajax跨域請求 獲取網(wǎng)頁中ajax數(shù)據(jù)
這篇文章主要介紹了基于iframe實現(xiàn)ajax跨域請求,并獲取網(wǎng)頁中ajax數(shù)據(jù),如何利用網(wǎng)頁ajax請求暴露出來的接口去抓取網(wǎng)頁數(shù)據(jù)?需要的朋友可以參考下2016-01-01
Jquery版本導致Ajax不執(zhí)行success回調函數(shù)
這篇文章主要介紹了Jquery Ajax不執(zhí)行success回調函數(shù)的原因及解決方法2014-04-04
Ajax 通過城市名獲取數(shù)據(jù)(全國天氣預報API)
本文給大家分享全國天氣預報API Ajax 通過城市名獲取數(shù)據(jù),通過html和js兩部分代碼實現(xiàn)天氣預報效果,輸入城市就會出現(xiàn)天氣情況,效果非常棒,感興趣的朋友可以參考下2016-11-11
ajax實現(xiàn)輸入框文字改變展示下拉列表的效果示例
這篇文章主要介紹了通過ajax實現(xiàn)輸入框文字改變展示下拉列表的效果,需要的朋友可以參考下2014-03-03

