快速解決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 表示用戶名為空,可以注冊(cè)
if(data=="1"){
alert("不能刪除,改組中有用");
flag=false;
}else{
flag=true;
}
})
if(flag==0){ //沒有有用戶
return true;
}else{
alert("改組中含有用戶,不能刪除");
return false;
}
}
}
問題: $.post的回調(diào)函數(shù)是在一個(gè)閉包中,有自己的作用域,返回值對(duì)于外部的函數(shù)不起作用,
可以在外部定義全局變量flag,但是 $.post異步請(qǐng)求,提前返回了flag, flag永遠(yuǎn)的默認(rèn)值,
解決方式: 使用$.ajax,把 異步請(qǐng)求設(shè)置為同步請(qǐng)求
其實(shí) ajax功能非常強(qiáng)大,可以直接不用拼接json
$.ajax({
url:url1,
async:false,
data:data1,
success:function(data){
flag=data;
}
以上這篇快速解決ajax返回值給外部函數(shù)的問題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
基于iframe實(shí)現(xiàn)ajax跨域請(qǐng)求 獲取網(wǎng)頁中ajax數(shù)據(jù)
這篇文章主要介紹了基于iframe實(shí)現(xiàn)ajax跨域請(qǐng)求,并獲取網(wǎng)頁中ajax數(shù)據(jù),如何利用網(wǎng)頁ajax請(qǐng)求暴露出來的接口去抓取網(wǎng)頁數(shù)據(jù)?需要的朋友可以參考下2016-01-01
PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評(píng)論
PHP Ajax實(shí)現(xiàn)頁面無刷新發(fā)表評(píng)論...2006-12-12
Jquery版本導(dǎo)致Ajax不執(zhí)行success回調(diào)函數(shù)
這篇文章主要介紹了Jquery Ajax不執(zhí)行success回調(diào)函數(shù)的原因及解決方法2014-04-04
Ajax 通過城市名獲取數(shù)據(jù)(全國天氣預(yù)報(bào)API)
本文給大家分享全國天氣預(yù)報(bào)API Ajax 通過城市名獲取數(shù)據(jù),通過html和js兩部分代碼實(shí)現(xiàn)天氣預(yù)報(bào)效果,輸入城市就會(huì)出現(xiàn)天氣情況,效果非常棒,感興趣的朋友可以參考下2016-11-11
jQuery使用ajax跨域請(qǐng)求獲取數(shù)據(jù)
跨域這個(gè)詞應(yīng)用非常頻繁,主要是因?yàn)榘踩拗?同源策略, 即JavaScript或Cookie只能訪問同域下的內(nèi)容)。本文給大家介紹jQuery使用ajax跨域請(qǐng)求獲取數(shù)據(jù),需要的朋友可以參考下2015-10-10
ajax實(shí)現(xiàn)輸入框文字改變展示下拉列表的效果示例
這篇文章主要介紹了通過ajax實(shí)現(xiàn)輸入框文字改變展示下拉列表的效果,需要的朋友可以參考下2014-03-03

