vue表单验证组件 v-verify-plugin

最近在整vue的表单验证,各种找插件;现在网上疯传的几种都试过了,各种报错,心都凉了,抱着不撞南墙不回头的的心态(ps:懒癌发作);终于找到了v-verify-plugin这个插件;头大的是最终自定义组件的时候终会报错,要哭了有没有???耗费一天,终于曲线救国成功,不废话,接下来一起看看吧

一、安装

    npm install vue-verify-plugin -S

二、初始 demo

  <template>
        <div class="input-box clearFix">
            <div>
                <input v-model="age" v-verify="age" placeholder="age"/>
                <label class="fl" v-remind="age"></label>
            </div>
            <div>
                <input type="text" class="phoneIcon fl" placeholder="手机号码" v-model="regInfo.phone" v-verify="regInfo.phone">
                <label class="fl" v-remind="regInfo.phone"></label>
            </div>
            <button v-on:click="submit">提交</button>
        </div>
    </template>

    <script>
        import Vue from "vue";
        import verify from "vue-verify-plugin";
        Vue.use(verify,{
            blur:true
        });

        export default {
            name: 'app',
            data () {
                return {
                    age:"",
                    regInfo: {
                        phone: ""
                    }
                }
            },
            verify: {
               age:"required",
               regInfo: {
                    phone: ["required","mobile"]
                }
            },
            methods:{
                submit: function () {
                    console.log(this.$verify.check());
                }
            }
        }
    </script>

指令说明

v-verify

在表单控件元素上创建数据的验证规则,他会自动匹配要验证的值以及验证的规则

v-verify 修饰符说明

该指令最后一个修饰符为自定义分组//自定义teacher分组

    //自定义teacher分组
    v-verify.teacher
    //自定义student分组
    v-verify.student

    //验证时可分开进行验证  

    //验证student 分组
    this.$verify.check("student")
    //验证teacher 分组
    this.$verify.check("teacher")
    //验证所有
    this.$verify.check();

v-verify指令也可使用 arg参数进行验证分组

如果同时使用修饰符和arg分组 则arg会覆盖修饰符分组

    v-verify:student
    //验证student 分组
    this.$verify.check("student")

v-remind 和 v-verified 验证错误提示

不得不吐槽一下,v-remind在自定义规则(或者说要验证长度的规则死报错有木有)
至于v-verified在2.0中已经被v-remind取代,但是在自定义规则中必须要用,手动蓝瘦

默认验证规则

  • email 邮箱规则验证

  • mobile 手机号码验证

  • required 必填

  • url 链接规则验证

  • maxLength 最多maxLength个字符串(可自定义message)

  • minLength 最少minLength个字符串(可自定义)

     <template>
       <div class="input-box clearFix">
         <div>
           <input type="text" class="phoneIcon fl" placeholder="手机号码" v-model="mobile" v-verify="mobile">
           <label class="fl" v-remind="mobile"></label>
         </div>
         <div>
         <div>
           <input type="text" placeholder="密码" v-verify="pwd" v-model="pwd" />
           <label v-verified="verifyError.pwd"></label>
         </div>
         <div>
           <input type="text" placeholder="username" v-verify="username" v-model="username" />
           <label v-verified="verifyError.username"></label>
         </div>
         <div>
           <input type="text" placeholder="phone" v-verify="phone" v-model="phone" />
           <label v-verified="verifyError.phone"></label>
         </div>
    
         <button v-on:click="submit">提交</button>
       </div>
     </template>
    
     <script>
       import Vue from "vue";
       import verify from "vue-verify-plugin";
    
       Vue.use(verify, {
         blur: true
       });
    
       export default {
         name: 'app',
         data() {
           return {
             mobile: "",
             username: "",
             pwd: "",
             phone: ""
           }
         },
         verify: {
           mobile: ["required", "mobile"],
           pwd: {      //默认插件,必须要用v-verified和计算属性,以下都是
             minLength: 6,
             message: "密码不得小于6位"
           },
           username: [     //自定义的插件
             "required",
             {
               test: function (val) {
                 if (val.length < 2) {
                   return false;
                 }
                 return true;
               },
               message: "姓名不得小于2位"
             }
           ],
           phone: {      //自定义的插件
             test: /^1[34578]\d{9}$/,
             message: "电话号码格式不正确"
           },
         },
         methods: {
           submit: function () {
             console.log(this.$verify.check());
           }
         },
         computed: {     //这个是关键,有长度的地方必须要有
           verifyError() {
             return this.$verify.$errors;
           }
         }
       }
     </script>
    

具体就这样啦,感谢setfocus大佬,但报错是真的,弄了一天要炸了有没有,手动笑哭

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,911评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 82,014评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 142,129评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,283评论 1 264
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,159评论 4 357
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,161评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,565评论 3 382
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,251评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,531评论 1 292
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,619评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,383评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,255评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,624评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,916评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,199评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,553评论 2 342
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,756评论 2 335

推荐阅读更多精彩内容