jquery 中ajax執(zhí)行的優(yōu)先級(jí)
今天在做用戶注冊(cè)時(shí):發(fā)現(xiàn)了一個(gè)奇怪的問(wèn)題,請(qǐng)看代碼:
$('input[name="username"]').blur(function(){ //驗(yàn)證格式 var pattern = /^[a-z][\w]{4,11}$/i; if(!pattern.test($(this).val())) { $(this).siblings('.desc').html('<font style="color:red;">5-12個(gè)字符,必須以字母開(kāi)頭,只能輸入數(shù)字,字母和下劃線</font>'); return false; } //驗(yàn)證用戶名是否被注冊(cè) $.post('register.php?act=checkUser',{username:$(this).val()},function(data){ if(data.status == 'error') { $('input[name="username"]').siblings('.desc').html('<font style="color:red;">'+data.info+'</font>'); return false; } },'json'); //成功 alert('成功'); //$(this).siblings('.desc').html('<img src="./public/images/ok.gif" />'); });
按道理說(shuō),上面的格式是
1、驗(yàn)證用戶名是否符合格式
2、格式正確再AJAX判斷用戶名是否被占用,
3、都成功則顯示正確的圖標(biāo),
但是問(wèn)題是當(dāng)我驗(yàn)證用戶格式成功了之后,它就直接執(zhí)行了,alert('成功'),然后再執(zhí)行ajax,這是為什么呢?是ajax執(zhí)行的時(shí)間問(wèn)題嗎?還是別的???
這是PHP代碼:
if($_GET['act'] == 'checkUser') { if($_SERVER['HTTP_X_REQUESTED_WITH'] !== 'XMLHttpRequest') exit('非法操作?。?!'); $sql = "SELECT id FROM {$sys_vars['db_pre']}user WHERE username='{$_POST['username']}'"; $result = mysql_query($sql); $data = mysql_fetch_assoc($result); if ($data) { exit(json_encode(array('status'=>'error','info'=>'該用戶名已被注冊(cè)!??!'))); }else{ exit(json_encode(array('status'=>'success'))); } }
分析如下
ajax是異步操作,當(dāng)執(zhí)行ajax相關(guān)功能函數(shù)時(shí),系統(tǒng)先返回函數(shù),再進(jìn)行請(qǐng)求,當(dāng)收到請(qǐng)求結(jié)果,會(huì)通過(guò)調(diào)用回調(diào)函數(shù)的方式返回給用戶。
$('input[name="username"]').blur(function(){ //驗(yàn)證格式 var pattern = /^[a-z][\w]{4,11}$/i; if(!pattern.test($(this).val())) { $(this).siblings('.desc').html('<font style="color:red;">5-12個(gè)字符,必須以字母開(kāi)頭,只能輸入數(shù)字,字母和下劃線</font>'); return false; } //驗(yàn)證用戶名是否被注冊(cè) $.post('register.php?act=checkUser',{username:$(this).val()},function(data){ if(data.status == 'error') { $('input[name="username"]').siblings('.desc').html('<font style="color:red;">'+data.info+'</font>'); return false; } }, function(data){ //對(duì)于post函數(shù),第三個(gè)參數(shù)為回調(diào)函數(shù) alert('成功'); } ,'json'); //成功 //alert('成功'); //$(this).siblings('.desc').html('<img src="./public/images/ok.gif" />'); });
照這樣修改一下,試試,體會(huì)一下不同之處。
不同的ajax函數(shù) 其回調(diào)函數(shù)的使用方法略有不同,可參考w3school的教程或jQuery官網(wǎng)。
這個(gè)其實(shí)是js的同步和異步的問(wèn)題,異步的話你可以想象一下兩條線路
--執(zhí)行函數(shù)調(diào)用--正則驗(yàn)證--發(fā)起ajax--函數(shù)返回 ajax回調(diào)
| |
| |
瀏覽器請(qǐng)求--php處理--瀏覽器接到結(jié)果
如果想讓函數(shù)返回在ajax回調(diào)之后,可以改變上邊的模型,例如:
--執(zhí)行函數(shù)調(diào)用--正則驗(yàn)證--發(fā)起ajax ajax回調(diào)--函數(shù)返回
| |
| |
瀏覽器請(qǐng)求--php處理--瀏覽器接到結(jié)果
這個(gè)可以通過(guò)修改jquery的發(fā)起ajax是異步還是同步方式來(lái)實(shí)現(xiàn)!
$('input[name="username"]').blur(function(){ //驗(yàn)證格式 var pattern = /^[a-z][\w]{4,11}$/i; if(!pattern.test($(this).val())) { $(this).siblings('.desc').html('<font style="color:red;">5-12個(gè)字符,必須以字母開(kāi)頭,只能輸入數(shù)字,字母和下劃線</font>'); return false; } //驗(yàn)證用戶名是否被注冊(cè) var ajaxCheckUser = false; $.ajax({ type: "POST", url: "register.php?act=checkUser", data: {username:$(this).val()}, // 注意這里 async:false success: function(data){ if(data.status == 'error') { $('input[name="username"]').siblings('.desc').html('<font style="color:red;">'+data.info+'</font>'); //return false; } else { ajaxCheckUser = true; } },'json'); if(ajaxCheckUser) { //成功 alert('成功'); //$(this).siblings('.desc').html('<img src="./public/images/ok.gif" />'); } });
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
- jQuery+AJAX實(shí)現(xiàn)無(wú)刷新下拉加載更多
- jQuery結(jié)合AJAX之在頁(yè)面滾動(dòng)時(shí)從服務(wù)器加載數(shù)據(jù)
- jQuery取消ajax請(qǐng)求的方法
- jQuery+ajax實(shí)現(xiàn)無(wú)刷新級(jí)聯(lián)菜單示例
- jQuery結(jié)合ajax實(shí)現(xiàn)動(dòng)態(tài)加載文本內(nèi)容
- php+ajax+jquery實(shí)現(xiàn)點(diǎn)擊加載更多內(nèi)容
- jQuery通過(guò)Ajax返回JSON數(shù)據(jù)
- PHP+jQuery+Ajax實(shí)現(xiàn)用戶登錄與退出
- JQuery中ajax方法訪問(wèn)web服務(wù)實(shí)例
相關(guān)文章
EasyUI 中combotree 默認(rèn)不能選擇父節(jié)點(diǎn)的實(shí)現(xiàn)方法
下面小編就為大家?guī)?lái)一篇EasyUI 中combotree 默認(rèn)不能選擇父節(jié)點(diǎn)的實(shí)現(xiàn)方法。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-11-11jQuery .tmpl(), .template()學(xué)習(xí)資料小結(jié)
昨晚無(wú)意中發(fā)現(xiàn)一個(gè)有趣的jQuery插件.tmpl(),其文檔在這里。2011-07-07jQuery中event.target和this的區(qū)別詳解
這篇文章主要介紹了jQuery中event.target和this的區(qū)別詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-08-08基于jQuery的的一個(gè)隔行變色,鼠標(biāo)移動(dòng)變色的小插件
基于jQuery的的一個(gè)隔行變色,鼠標(biāo)移動(dòng)變色的小插件,學(xué)習(xí)jquery的朋友可以參考下。2010-07-07jquery實(shí)現(xiàn)的3D旋轉(zhuǎn)木馬特效代碼分享
這篇文章主要介紹了jquery實(shí)現(xiàn)的3D旋轉(zhuǎn)木馬特效,功能實(shí)現(xiàn)非常簡(jiǎn)單,推薦給大家,有需要的小伙伴可以參考下。2015-08-08jquery isEmptyObject判斷是否為空對(duì)象的函數(shù)
jQuery 判斷一個(gè)對(duì)象是否為空是使用for name in obj 來(lái)遍歷對(duì)象中的屬性名.2011-02-02