利用jquery.validate非同步驗證使用者名稱是否存在
HTML頭部引用:
<script type="text/javascript" src="../js/jquery-1.3.2.min.js"></script>
<script type="text/javascript" src="../js/jquery.validate.min.js"></script>
<script type="text/javascript" src="../js/messages_cn.js"></script>
HTML內容(部分):
<form name="form1" id="form1" method="post" action="">
<dl>
<dt>使用者名稱:</dt>
<dd><input name="txtUserName" id="txtUserName" type="text" class="input1" /></dd>
</dl>
</form>
JS程式碼部分:
$(function() {
//表單驗證JS
$("#form1").validate({
//出錯時新增的標籤
errorElement: "span",
rules: {
txtUserName: {
required: true,
minlength: 3,
maxlength: 16,
remote: {
type: "post",
url: "/tools/ValidateUserName.ashx",
data: {
username: function() {
return $("#txtUserName").val();
}
},
dataType: "html",
dataFilter: function(data, type) {
if (data == "true")
return true;
else
return false;
}
}
}
},
success: function(label) {
//正確時的樣式
label.text(" ").addClass("success");
},
messages: {
txtUserName: {
required: "請輸入使用者名稱,3-16個字元(字母、數字、下劃線),註冊後不能更改",
minlength: "使用者名稱長度不能小於3個字元",
maxlength: "使用者名稱長度不能大於16個字元",
remote: "使用者名稱不可用"
}
}
});
});
應注意的地方:
data: {
username: function() {
return $("#txtUserName").val();
}
有返回值,如果直接寫“data: {username: $("#txtUserName").val();}”,這樣是獲取不到值的。