最近在做會員註冊這塊。用了jquery的 ajax 驗證使用者名稱。郵箱,驗證碼
function check_email()
{
var check_email = $("#reg_mail").val();
var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((/.[a-zA-Z0-9_-]{2,3}){1,2})$/;
flag = reg.test(check_email);
if(flag)
{
var email_value = $('#reg_mail').val();
$.get("[var.base_url]register.php",{check_name:"email",check_value:email_value,async:false},function(json){
//$('#res_mail').html(json);
if(json == "ok")
{
$('#res_mail').html("<font color='green' font-size='12'><b>此email可以註冊!</b></font>");
return true;
}else{
$('#res_mail').html("<font color='red' font-size='12'><b>此email已被註冊!</b></font>");
return false;
}
});
}else{
$("#res_mail").html("<font color='red' font-size='12'><b>請輸入正確的郵箱地址!</b></font>");
return false;
}
}
開始是這麼寫的。 可是總是無法擷取到返回的狀態true 或false 返回一個undefined 查了很多資料。csdn上的一個文章很經典:
var boolean = false;
$.get(url,null,function(data){//理解這個不難,只要你Crowdsourced Security Testing道jquery中的方法返回的都是jquery的對象或jquery指定的對象。
//jquery的get、post等ajax方法預設是非同步互動方式,所以在get方法還沒有執行完成的時候就已經return了,這時的bl就是你定義的bl = false;所以一直返回false;改成同步的應該有值了
//所以要想放回bl的正確值,你得改下get方法。一般不在ajax方法中做傳回值處理。
//可以用$.data("bl", bl);儲存你的值,然後用$.data("bl")取值。
if(data.indexOf("true")>=0){
$("#mid").html("登陸成功");
bl = true;
$.data("bl", bl);
}
else{
$("#mid").html("使用者名稱或密碼錯誤");
bl = false;
$.data("bl", bl);
}
});
return bl;
這樣就可以擷取到返回的狀態了。用data方法 儲存 值。然後擷取。還有一個方法就是
$.get(url,{async: false},function(data) 設定傳輸方式為同步傳輸
最終修改函數如下。 測試ok。
function check_email()
{
var check_email = $("#reg_mail").val();
var reg = /^([a-zA-Z0-9_-])+@([a-zA-Z0-9_-])+((/.[a-zA-Z0-9_-]{2,3}){1,2})$/;
flag = reg.test(check_email);
if(flag)
{
var email_value = $('#reg_mail').val();
$.get("[var.base_url]register.php",{check_name:"email",check_value:email_value,async:false},function(json){
//$('#res_mail').html(json);
if(json == "ok")
{
$('#res_mail').html("<font color='green' font-size='12'><b>此email可以註冊!</b></font>");
tamp_email = true;
$.data("tamp_email",tamp_email);
//$('#sub_reg').attr("disabled", false);
}else{
$('#res_mail').html("<font color='red' font-size='12'><b>此email已被註冊!</b></font>");
tamp_email = false;
$.data("tamp_email",tamp_email);
//$('#sub_reg').attr("disabled", true);
}
});
return tamp_email;
}else{
$("#res_mail").html("<font color='red' font-size='12'><b>請輸入正確的郵箱地址!</b></font>");
return false;
}
}