BootstrapValidator,最好用的bootstrap表单验证插件

  1. 云栖社区>
  2. 博客>
  3. 正文

BootstrapValidator,最好用的bootstrap表单验证插件

沉默王二 2015-10-13 17:50:33 浏览1329
展开阅读全文
版权声明:欢迎转载,请注明沉默王二原创。 https://blog.csdn.net/qing_gee/article/details/49101931

本篇推荐一款twitter做的BootstrapValidator,本身Bootstrap就是twitter做的,那么使用原配的validator也就更值得信赖。从百度上搜BootstrapValidator会出现很多款,但我只推荐这款(突然感觉自己有点“库【Steve 库里】吹”的感觉)。

这里写图片描述

一、一睹为快

这里写图片描述
为了简便的介绍,这里只做为空的check。

BootstrapValidator官方下载地址

二、资源引用

下载完资源包后,你可以看到如下的目录。
这里写图片描述

然后把以下三个文件引入到你项目。

<link type="text/css" rel="stylesheet" href="${ctx}/components/validate/css/bootstrapValidator.css" />
<script type="text/javascript" src="${ctx}/components/validate/js/bootstrapValidator.js"></script>
<script type="text/javascript" src="${ctx}/components/validate/js/language/zh_CN.js"></script>

三、会员名称不为空项目配置

<form class="form-signin required-validate" action="${ctx}/login" method="post" onsubmit="return validateCallback(this)">
    <div class="form-group">
        <div class="row">
            <label>账户</label>
            <input class="form-control" type="text" autofocus name="username" placeholder="请输入会员编号" autocomplete="off"
                data-bv-notempty />
        </div>
    </div>
</form>
  1. data-bv-notempty表示该会员编号要做为空check。
  2. form-group的div是必须的,否则会报“too much recursion”错误。
  3. form表单提交的时候会执行validateCallback方法,该方法在第五步中具体介绍。

四、页面加载完成后启用bootstrap validator


$(function() {
    // validate form
    $("form.required-validate").each(function() {
        var $form = $(this);
        $form.bootstrapValidator();

        // 修复bootstrap validator重复向服务端提交bug
        $form.on('success.form.bv', function(e) {
            // Prevent form submission
            e.preventDefault();
        });


    });
});
  1. 在form表单上加上‘class=”required-validate”’属性,然后通过jquery获取对应form表单,对其执行默认的bootstrapValidator加载。
  2. 一定要注意上面代码中注释部分代码,具体介绍可参照修复BootstrapValidator重复提交的bug

五、form表单提交时验证项目

function validateCallback(form, callback, confirmMsg) {
    YUNM.debug("进入到form表单验证和提交");

    var $form = $(form);

    var data = $form.data('bootstrapValidator');
    if (data) {
    // 修复记忆的组件不验证
        data.validate();

        if (!data.isValid()) {
            return false;
        }
    }


    $.ajax({
        type : form.method || 'POST',
        url : $form.attr("action"),
        data : $form.serializeArray(),
        dataType : "json",
        cache : false,
        success : callback || YUNM.ajaxDone,
        error : YUNM.ajaxError
    });

    return false;
}
  1. validateCallback中获取form表单后,通过isValid方法可以返回表单验证是否通过。
  2. 当表单验证通过后,再通过ajax将表单提交到服务端。

感谢您阅读【沉默王二的博客】,如果王二的博客给您带来一丝帮助或感动,我(也就是王二)将不甚荣幸。
如果您碰巧喜欢,可以留言或者私信我,这将是我鼓捣更多优秀文章的最强动力。

网友评论

登录后评论
0/500
评论
沉默王二
+ 关注