zoukankan      html  css  js  c++  java
  • bootstrapValidator.js 做表单验证

    有这样的一个场景,我们在提交form表单的时候 可能要做一些验证,比如判断是不是为空,电话的格式验证,邮箱的格式验证等等,手写起来也是可以得。

    但是今天我介绍一个bootstrap插件简化开发。就是bootstrapValidator.js。

    直接上手写代码。

    1。首先 jquery,bootstrap 以及bootstrapValidator(地址https://github.com/nghuuphuoc/bootstrapvalidator

    2.引用jquery bootstrap  bootstrapValidator(css ,js文件都需要引用)

    3.代码

    <form action="/Account/Register" method="post" id="registerForm">
        @Html.AntiForgeryToken()
        <div style="margin:0 auto; 400px;">
            <div class="form-group">
                <label> Email:</label>
                <input type="text" name="email" id="txtEmail" class="form-control" />
            </div>
            <div class="form-group">
                <label> 用户名:</label>
                <input type="text" name="Username" id="txtRegisterUsername" class="form-control" />
            </div>
            <div class="form-group">
                <label> 密  码:</label>
                <input type="password" name="Password" id="txtRegisterPassword" class="form-control" />
            </div>
            <div class="form-group">
                <label> 密码重复:</label>
                <input type="password" name="Confirm" id="txtConfirm" class="form-control" />
            </div>
            <button type="submit" id="btnRegister" class="btn btn-primary">注册</button>
            <button type="reset" class="btn btn-default" id="btnRegister">重置</button>
        </div>
    </form>

    重点就在下面:

      $('#registerForm').bootstrapValidator({
            message: '这个值没有被验证',
            feedbackIcons: {
                valid: 'glyphicon glyphicon-ok',
                invalid: 'glyphicon glyphicon-remove',
                validating: 'glyphicon glyphicon-refresh'
            },
            fields: {
                email: {
                    validators: {
                        notEmpty: {
                            message: '邮箱是必填项'
                        },
                        emailAddress: {
                            message: '邮箱格式正确'
                        }
                    }
                },
                Username: {
                    message: '用户名还没有验证',
                    validators: {
                        notEmpty: {
                            message: '用户名不能为空'
                        },
                        stringLength: {
                            min: 1,
                            max: 16,
                            message: '用户名长度在1到16位之间'
                        }
                    }
                },
                Password: {
                    message: '密码还没有验证',
                    validators: {
                        notEmpty: {
                            message: '密码不能为空'
                        },
                        stringLength: {
                            min: 6,
                            max: 16,
                            message: '密码长度在6到16之间'
                        },
                        different: {
                            field: 'Username',
                            message: '密码不能和用户名相同'
                        }
                    }
                },
                Confirm: {
                    message: '密码重复还没有验证',
                    validators: {
                        notEmpty: {
                            message: '密码重复不能为空'
                        },
                        stringLength: {
                            min: 6,
                            max: 16,
                            message: '密码长度在6到16之间'
                        },
                        identical: {
                            field: 'Password',
                            message: '两次密码不同请重新输入'
                        }
                    }
                }
            }
        }).on('success.form.bv', function (e) {
            // Prevent form submission
            e.preventDefault();
            // Get the form instance
            var $form = $(e.target);
            // Get the BootstrapValidator instance
            var bv = $form.data('bootstrapValidator');
            // Use Ajax to submit form data
            $.post("/Account/Register", $form.serialize(), function (data) {
                console.log(data)
                if (data.Status == "ok") {
                    window.location.href = "/Home/Index";
                }
                else if (data.Status == "error") {
                    alert(data.Message);
                }
                else {
                    alert("未知错误");
                }
            });
        });

    看看效果:

    注意下:

    这个input的样式必须是这种方式(特别是form-group)

    不然会报错。

      <div class="form-group">
                <label> Email:</label>
                <input type="text" name="email" id="txtEmail" class="form-control" />
            </div>
  • 相关阅读:
    vue: 从组件通讯到vuex (上)
    js创建常量
    表单验证封装
    我之理解js作用域,作用域链与变量提升
    @ngModule 结构分析
    ionic3 angular项目目录结构解析
    vue 绑定数组里面对象变化无法更新view
    input日历类型placeholder移动端不起作用
    js移动端 虚拟键盘提交事件
    页面调转
  • 原文地址:https://www.cnblogs.com/nele/p/5493414.html
Copyright © 2011-2022 走看看