DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> 妙用Bootstrap的 popover插件實現校驗表單提示功能
妙用Bootstrap的 popover插件實現校驗表單提示功能
編輯:關於JavaScript     

最近的項目,用Bootstrap比較多。浏覽Bootstrap文檔,發現 popover 插件特別適合做表單校驗出錯的提示。

因為使的非常頻繁,最近把它封住下,做成 jQuery的插件。 通過 本插件,在 html標簽中 定義好 data-vaild=”校驗正則” data-errmsg=”錯誤信息即可”。為什麼 要把 校驗規則 寫到 html 標簽中呢?因為 我還用它做了 後台 的校驗規則(後台沒用Node,現在用的ASP,忙完專門再發文寫下原理)。

<input class="form-control" id="u_exam_idnumber" name="u_exam_idnumber" placeholder="請輸入中考准考證號" data-vaild="^\d{5,20}$" data-errmsg="准考證號碼不正確,僅能包含數字"

最終實現的效果如下:

插件代碼如下:

"use strict";
/*
jQuery+Bootstrap 校驗表單 by Miaoqiyuan.cn
原理:http://www.miaoqiyuan.cn/p/jquery-bootstrap-vaild
演示:http://www.miaoqiyuan.cn/products/vaild/index.html
源碼:http://www.miaoqiyuan.cn/products/vaild/jQuery.Vaild.js
*/
(function(jQuery){
$.extend({
Vaild : function(_this){
if( !!$(_this).data("vaild") ){
var pattern = new RegExp($(_this).data("vaild"));
if( pattern.test( $(_this).val() ) ){
$(_this).parent().removeClass("has-error").addClass("has-success");
$(_this).popover("destroy");
}else{
$(_this).parent().addClass("has-error").removeClass("has-success");
$(_this).data("toogle", "top").data("placement", "top").data("container", "body").data("content", $(_this).data("errmsg")).popover({"trigger":"manual"}).popover("show");
return false;
}
}else{
$(_this).parent().addClass("has-success");
}
return true;
}
});
$.fn.extend({
Vaild : function(){
$(this).each(function(index, _this){
$(_this).submit(function(){
var checkResult = true;
for(var i = 0 ; i < _this.length; i++ ){
checkResult = $.Vaild(_this[i]) && checkResult;
}
return checkResult;
});
for(var i = 0 ; i < _this.length; i++ ){
$(_this[i]).blur(function(){
$.Vaild(this);
});
}
});
}
});
})(jQuery);

調用的時候非常簡單,直接使用以下代碼:

<script>
$("form").Vaild();
</script>

當表單失去焦點時,如果不合法,會直接提示錯誤。點擊提交時,如果有表單項目不合法,會阻止表單繼續提交。

popoover默認的背景是 白色的,不能起到 警示作用,而且 padding 設置過大,太占用空間了。 最後調整下CSS,就實現了 截圖的效果。

/*重構 popover */
.popover{background:#C00;color:#FFF;}
.popover .popover-content{padding:1px 5px;}
.popover.top>.arrow:after{border-top-color:#C00;}
/*重構 bootstrap 默認錯誤提示 */
.has-error input,
.has-error textarea,
.has-error select{background-color:#F2DEDE;}
.has-success input,
.has-success textarea,
.has-success select{background-color:#DFF0D8}

以上所述是小編給大家介紹的Bootstrap的 popover插件實現校驗表單提示功能,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對網站的支持!

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved