1. 程式人生 > >Jquery 組 表單驗證

Jquery 組 表單驗證

label red turn set tips 全部 erro ons htm

<!DOCTYPE html>
<html lang="zh-cn">
<head>
<meta charset="utf-8">
<title></title>
<style>
</style>
</head>
<body>
<form action="" method="post">
<div class="int">
<label for="username">用戶名:</label>
<input type="text" id="username" class="required"/>
</div>
<div class="int">
<label for="email">郵箱:</label>
<input type="text" id="email" class="required"/>
</div>
<div class="sub">
<input type="submit" value="提交" id="send"/>
<input type="reset" value="重置" id="res"/>
</div>
</form>
</body>
<script src="js/jquery-1.11.3.js"></script>
<script>
$("form :input.required").each(function(){
// 先清除已經加上的
var $required=$("<strong style=‘color:red‘ class=‘high‘>*</strong>");
$(this).parent().append($required);
});
$(‘form :input‘).blur(function(){
var $parent=$(this).parent();
$parent.find(".formtips").remove();
if($(this).is(‘#username‘)){
if(this.value==""||this.value.length<6){
var erroMsg=‘請輸入至少6位的用戶名.‘;
$parent.append(‘<span class="formtips onError" >‘+erroMsg+‘</span>‘)
}else{
var okMsg=‘輸入正確.‘;
$parent.append(‘<span class="formtips onSuccess" >‘+okMsg+‘</span>‘)
}
}
if($(this).is(‘#email‘)){
if(this.value==""||(this.value!=""&&!/.+@.+\.[a-zA-Z]{2,4}$/.test(this.value))){
var eerroMsg=‘請輸入正確的E-Mail地址.‘;
$parent.append(‘<span class="formtips onError" >‘+eerroMsg+‘</span>‘)
}else{
var eokMsg=‘輸入正確.‘;
$parent.append(‘<span class="formtips onSuccess" >‘+eokMsg+‘</span>‘)
}
}
}).keyup(function(){
$(this).triggerHandler("blur");
}).focus(function(){
$(this).triggerHandler("blur");
});
// 觸發事件,全部再檢驗一次
$(‘#send‘).click(function(){
$("form .required:input").trigger(‘blur‘);
var numError=$(‘form .onError‘).length;
if(numError){
return false;
}
alert("註冊成功,密碼已經發到你的郵箱,請查收。");
})
// trigger() 方法觸發被選元素上指定的事件以及事件的默認行為(比如表單提交)。
// 該方法與 triggerHandler() 方法類似,不同的是 triggerHandler() 不觸發事件的默認行為。
// 與 triggerHandler() 方法相比的不同之處:
// 它不會引起事件(比如表單提交)的默認行為
// .trigger() 會操作 jQuery 對象匹配的所有元素,而 .triggerHandler() 只影響第一個匹配元素。
// 由 .triggerHandler() 創建的事件不會在 DOM 樹中冒泡;如果目標元素不直接處理它們,則不會發生任何事情。
</script>
</html>

Jquery 組 表單驗證