Jquery 組 表單驗證

來源:互聯網
上載者:User

標籤:處理   utf-8   trigger   表單   冒泡   地址   on()   style   觸發事件   

<!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!=""&&!/[email protected]+\.[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 組 表單驗證

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.