jquery 中ajax執(zhí)行的優(yōu)先級(jí)
今天在做用戶(hù)注冊(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ù)字,字母和下劃線(xiàn)</font>');
return false;
}
//驗(yàn)證用戶(hù)名是否被注冊(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)證用戶(hù)名是否符合格式
2、格式正確再AJAX判斷用戶(hù)名是否被占用,
3、都成功則顯示正確的圖標(biāo),
但是問(wèn)題是當(dāng)我驗(yàn)證用戶(hù)格式成功了之后,它就直接執(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'=>'該用戶(hù)名已被注冊(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ù)的方式返回給用戶(hù)。
$('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ù)字,字母和下劃線(xiàn)</font>');
return false;
}
//驗(yàn)證用戶(hù)名是否被注冊(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)題,異步的話(huà)你可以想象一下兩條線(xià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ù)字,字母和下劃線(xiàn)</font>');
return false;
}
//驗(yàn)證用戶(hù)名是否被注冊(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)用戶(hù)登錄與退出
- JQuery中ajax方法訪(fǎng)問(wèn)web服務(wù)實(shí)例
相關(guān)文章
jQuery里filter()函數(shù)與find()函數(shù)用法分析
這篇文章主要介紹了jQuery里filter()函數(shù)與find()函數(shù)用法,實(shí)例對(duì)比分析了filter()函數(shù)與find()函數(shù)的功能與相關(guān)使用技巧,需要的朋友可以參考下2015-06-06
jQuery中的deferred對(duì)象和extend方法詳解
本篇文章主要介紹了jQuery中的deferred對(duì)象和extend方法,具有很好的參考價(jià)值。下面跟著小編一起來(lái)看下吧2017-05-05
jquery實(shí)現(xiàn)彈出層登錄和全屏層注冊(cè)特效
這篇文章主要為大家詳細(xì)介紹了jquery實(shí)現(xiàn)彈出層登錄和全屏層注冊(cè)特效,推薦給大家,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2015-08-08
jQuery EasyUI tree 使用拖拽時(shí)遇到的錯(cuò)誤小結(jié)
在我使用tree拖拽時(shí)總是失敗,控制臺(tái)輸出了很多錯(cuò)誤。經(jīng)過(guò)問(wèn)題跟蹤分析最終找到的錯(cuò)誤原因,下面小編給大家分享下,感興趣的朋友參考下2016-10-10
z-blog SyntaxHighlighter 長(zhǎng)代碼無(wú)法換行解決辦法(基于jquery)
這篇文章主要介紹了z-blog SyntaxHighlighter 長(zhǎng)代碼無(wú)法換行解決辦法(jquery),需要的朋友可以參考下2015-11-11
jQuery實(shí)現(xiàn)簡(jiǎn)單輪播圖效果
這篇文章主要為大家詳細(xì)介紹了jQuery實(shí)現(xiàn)簡(jiǎn)單輪播圖效果,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
一次$.getJSON不執(zhí)行的簡(jiǎn)單記錄
下面小編就為大家?guī)?lái)一篇一次$.getJSON不執(zhí)行的簡(jiǎn)單記錄。小編覺(jué)得挺不錯(cuò)的,現(xiàn)在就分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2016-07-07
jQuery 實(shí)現(xiàn)鼠標(biāo)畫(huà)框并對(duì)框內(nèi)數(shù)據(jù)選中的實(shí)例代碼
本文通過(guò)實(shí)例代碼給大家介紹了jQuery 實(shí)現(xiàn)鼠標(biāo)畫(huà)框并對(duì)框內(nèi)數(shù)據(jù)選中的實(shí)例代碼,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧2017-08-08

