码迷,mamicode.com
首页 > 其他好文 > 详细

vue-validator(vue验证器)

时间:2016-07-28 15:16:02      阅读:615      评论:0      收藏:0      [点我收藏+]

标签:

官方文档:http://vuejs.github.io/vue-validator/zh-cn/index.html

github项目地址:https://github.com/vuejs/vue-validator

单独使用vue-validator的方法见官方文档,本文结合vue-router使用。

安装验证器

不添加自定义验证器或者无需全局使用的公用验证器,在main.js中安装验证器,使用 CommonJS 模块规范, 需要显式的使用 Vue.use() 安装验证器组件。

import Validator from ‘vue-validator‘
Vue.use(Validator)

vue-router 同时使用,必须在调用 router#map, router#start 等实例方法前安装验证。 

若要自定义验证器,建一个js文件,在该文件中安装验证器组件。例如:validation.js

import Vue from ‘vue‘
import Validator from ‘vue-validator‘
Vue.use(Validator)
//自定义验证器

自定义验证器

官方提供的api如下

input[type="text"]
input[type="radio"]
input[type="checkbox"]
input[type="number"]
input[type="password"]
input[type="email"]
input[type="tel"]
input[type="url"]
select
textarea

但是以上的不一定满足我们的需求,这时就需要用到另一个全局api,用于注册和获取全局验证器。

Vue.validator( id, [definition] )

示例  定义validation.js  内容如下

import Vue from ‘vue‘
import Validator from ‘vue-validator‘
Vue.use(Validator)
//自定义验证器
//添加一个简单的手机号验证 //匹配0-9之间的数字,并且长度是11位 Vue.validator(‘tel‘, function (val) { return /^[0-9]{11}$/.test(val) }); //添加一个密码验证 //匹配6-20位的任何字类字符,包括下划线。与“[A-Za-z0-9_]”等效。 Vue.validator(‘passw‘, function (val) { return /^(\w){6,20}$/.test(val) });

使用验证器

验证器语法

<validator name="validation">
    <input type="text" v-model=‘comment‘ id=‘comment‘ v-validate:comment="{ minlength: 3, maxlength: 15 }">
    <div>
      <span v-show="$validation.comment.minlength">不得少于3个字符</span>
      <span v-show="$validation.comment.maxlength">不得大于15个字符</span>
    </div>
 </validator>

默认情况下,vue-validator 会根据 validator 和 v-validate 指令自动进行验证。然而有时候我们需要关闭自动验证,在有需要时手动触发验证。如果你不需要自动验证,可以通过 initial 属性或 v-validate 验证规则来关闭自动验证。如下:

<validator name="validation">
     <input type="text" v-model=‘comment‘ id=‘comment‘ v-validate:comment="{ minlength: 3, maxlength: 15 }"  detect-change="off" initial=‘off‘>
     <div>
       <span v-show="$validation.comment.minlength">不得少于3个字符</span>
       <span v-show="$validation.comment.maxlength">不得大于15个字符</span>
     </div>
</validator>

Terminal 指令问题

<validator name="test_validator">
    <!-- @invalid:valid的逆 ,表示验证不通过 -->
    <input  @invalid="passwInvalid" @valid="passwok" type="password" v-model=‘passw‘ id=‘passw‘ v-validate:passw="[‘passw‘]"  detect-change="off" initial=‘off‘ placeholder=‘请输入密码‘>
    <input  @invalid="passwInvalid" @valid="passwok" type="password" v-model=‘passw2‘ id=‘passw2‘ v-validate:passw2="[‘passw‘]"  detect-change="off" initial=‘off‘ placeholder=‘请输入密码‘>
</validator>
<script>
//若是在main.js中导入  无需再次导入
//此处导入的是上面代码的validation.js
import validator from ../validator/validation export default{ data(){ return{ comment:‘‘, passw:‘‘, passw2:‘‘ } }, methods:{ passwInvalid(){ alert(只能输入6-20个字母、数字、下划线); }, passwok(){ //alert(‘验证码符合规范‘) } } } </script>

 示例:用户注册流程

vue-validator(vue验证器)

标签:

原文地址:http://www.cnblogs.com/jyichen/p/5660886.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!