文章詳情頁
快速解決ajax返回值給外部函數(shù)的問題
瀏覽:462日期: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 表示用戶名為空,可以注冊 if(data=="1"){ alert("不能刪除,改組中有用"); flag=false; }else{ flag=true; } }) if(flag==0){ //沒有有用戶 return true; }else{ alert("改組中含有用戶,不能刪除"); return false; } } }
問題: $.post的回調(diào)函數(shù)是在一個閉包中,有自己的作用域,返回值對于外部的函數(shù)不起作用,
可以在外部定義全局變量flag,但是 $.post異步請求,提前返回了flag, flag永遠(yuǎn)的默認(rèn)值,
解決方式: 使用$.ajax,把 異步請求設(shè)置為同步請求
其實 ajax功能非常強大,可以直接不用拼接json
$.ajax({ url:url1, async:false, data:data1, success:function(data){ flag=data; }
以上這篇快速解決ajax返回值給外部函數(shù)的問題就是小編分享給大家的全部內(nèi)容了,希望能給大家一個參考,也希望大家多多支持。
標(biāo)簽:
Ajax
相關(guān)文章:
1. 解決AJAX返回狀態(tài)200沒有調(diào)用success的問題2. bootstrap select2 動態(tài)從后臺Ajax動態(tài)獲取數(shù)據(jù)的代碼3. Ajax請求超時與網(wǎng)絡(luò)異常處理圖文詳解4. ThinkPHP5 通過ajax插入圖片并實時顯示(完整代碼)5. ajax實現(xiàn)頁面的局部加載6. axios和ajax的區(qū)別點總結(jié)7. laravel ajax curd 搜索登錄判斷功能的實現(xiàn)8. 關(guān)于Ajax跨域問題及解決方案詳析9. 利用ajax+php實現(xiàn)商品價格計算10. Ajax提交post請求案例分析
排行榜
