文章詳情頁(yè)
快速解決ajax返回值給外部函數(shù)的問(wèn)題
瀏覽:454日期:2022-06-11 13:26:13
如下所示:
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){ //沒(méi)有有用戶 return true; }else{ alert("改組中含有用戶,不能刪除"); return false; } } }
問(wèn)題: $.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ù)的問(wèn)題就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持。
標(biāo)簽:
Ajax
相關(guān)文章:
1. 前后端ajax和json數(shù)據(jù)交換方式2. Ajax實(shí)現(xiàn)登錄案例3. Ajax請(qǐng)求超時(shí)與網(wǎng)絡(luò)異常處理圖文詳解4. AJAX請(qǐng)求以及解決跨域問(wèn)題詳解5. Ajax返回值類型與用法實(shí)例分析6. 關(guān)于ajax異步訪問(wèn)數(shù)據(jù)的問(wèn)題7. 淺析Django 接收所有文件,前端展示文件(包括視頻,文件,圖片)ajax請(qǐng)求8. AJAX檢測(cè)用戶名是否存在的方法9. ajax實(shí)現(xiàn)提交時(shí)校驗(yàn)表單方法10. 爬取今日頭條Ajax請(qǐng)求
排行榜
