文章詳情頁
快速解決ajax返回值給外部函數(shù)的問題
瀏覽:706日期: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永遠的默認值,
解決方式: 使用$.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對xml信息的接收和處理操作實例分析2. Python生成器傳參數(shù)及返回值原理解析3. Ajax原理與應(yīng)用案例快速入門教程4. layui的checbox在Ajax局部刷新下的設(shè)置方法5. PHP ajax跨子域的解決方案之document.domain+iframe實例分析6. 利用ajax+php實現(xiàn)商品價格計算7. pjax:ajax和pushState結(jié)合的js庫——實現(xiàn)網(wǎng)站無刷新加載頁面8. Ajax+PHP簡單入門教程9. 原生Ajax之全面了解xhr的概念與使用10. 解決ajax請求后臺,有時收不到返回值的問題
排行榜

網(wǎng)公網(wǎng)安備