vue-validator(vue驗證器)

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

github項目地址:https://github.com/vuejs/vue-validatorvue

單獨使用vue-validator的方法見官方文檔,本文結合vue-router使用。git

安裝驗證器github

不添加自定義驗證器或者無需全局使用的公用驗證器,在main.js中安裝驗證器,使用 CommonJS 模塊規範, 須要顯式的使用 Vue.use() 安裝驗證器組件。web

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

vue-router 同時使用,必須在調用 router#map, router#start 等實例方法前安裝驗證。 vue-router

若要自定義驗證器,建一個js文件,在該文件中安裝驗證器組件。例如:validation.jsapi

import Vue from 'vue'
import Validator from 'vue-validator'
Vue.use(Validator)
//自定義驗證器

自定義驗證器併發

官方提供的api以下ide

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,用於註冊和獲取全局驗證器。post

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>

 示例:用戶註冊驗證

用了一個組件來顯示提示信息

toast.vue

<template>
    <div v-show="toastshow" transition="toast" class="toast font-normal">
        {{toasttext}}
    </div>
</template>
<script>
export default{
    props:{
        //是否顯示提示
        toastshow:{
            type:Boolean,
              required: false,
            default:function(){
                return false;
            }
        },
        //提示的內容
        toasttext:{
            type:String,
            required: false,
            default:function(){
                return 'no message';
            }
        },
        //顯示的時間
        duration: {
            type: Number,
            default:3000,//默認3秒
            required:false
        }        
    },
    ready() {
        
    },
    watch:{
        toastshow(val){
            if (this._timeout) clearTimeout(this._timeout)
            if (val && !!this.duration) {
             this._timeout = setTimeout(()=> this.toastshow = false, this.duration)
            }
        }
    }
}
</script>
<style>
    .toast{
        position:absolute;
        left:50%;
        margin-left:-25%;
        bottom:30px;
        display:block;
        width:200px;
        height:auto;
        text-align:center;
        color:white;
        background-color:rgba(0,0,0,0.5);
        border-radius:10px;
        z-index:10;
        transform:scale(1);
        padding:5px;
    }
    .toast-transition{
        transition: all .3s ease;
    }
    .toast-enter{
        opacity:0;
        transform:scale(0.1);
    }
    .toast-leave{
        opacity:0;
        transform:scale(0.1);
    }
</style>

註冊用戶:假如咱們須要填寫手機號和輸入兩次密碼

<template>
    <div class='register-box'>
        <!-- 組件:用於顯示提示信息 -->
        <Toast :toastshow.sync="toastshow" :toasttext="toasttext"></Toast>
        <validator name="validation_register1">
        <div class='register1'>
            <div class='pd05'>
            <input @invalid="telonInvalid" initial="off" detect-change="off" v-model="telphone" id="telphone" type="tel" class='phone-number' v-validate:telphone="['tel']"  placeholder='請輸入手機號碼'>
            </div>
            <div class='pd05'>
                <input @invalid="passwInvalid" v-model="passw1" initial="off"  detect-change="off" id="passw1" type="password" v-validate:passw1="['passw']" class='password-number'  placeholder='請輸入密碼'>
            </div>
            <div class='pd05'>
                <input @invalid="passwInvalid" v-model="passw2" initial="off" detect-change="off" id="passw2" type="password" v-validate:passw2="['passw']" class='password-number'  placeholder='請輸入密碼'>
            </div>
            <a class='greenBtn' v-on:click='register_user()'>下一步</a>
        </div>
        </validator>
    </div>
</template>
<script>
//導入validation.js  此處的validation.js就是上文中validation.js的內容
import validator from '../validator/validation';
//導入顯示提示信息的組件
import Toast from '../components/toast.vue';
export default{    
    components: {
        //註冊組件
          Toast
      },
    data(){
        return{
            telphone:'',//電話號碼
            toastshow:false,//默認不現實提示信息
            toasttext:'',//提示信息內容
            passw1:'',//首次輸入密碼
            passw2:''//再次輸入密碼
        }
    },
    methods:{
        //手機號驗證失敗時執行的方法
        telonInvalid(){
            //設置提示信息內容
            this.$set('toasttext','手機不正確');
            //顯示提示信息組件
            this.$set('toastshow',true);
        },
        //密碼驗證失敗時執行的方法
        passwInvalid(){
            this.$set('toasttext','只能輸入6-20個字母、數字、下劃線');
            this.$set('toastshow',true);
        },    
        register_user(){
            var that = this;
            var telephones = that.$get('telphone');
            var pw1 = that.$get('passw1');
            var pw2 = that.$get('passw2')  
            that.$validate(true, function () {            
                if (that.$validation_register1.invalid) {
                    //驗證無效
                      that.$set('toasttext','請完善表單');
                     that.$set('toastshow',true);
                }else{
                     that.$set('toasttext','驗證經過');
                     that.$set('toastshow',true);
                     //驗證經過作註冊請求
                     /*that.$http.post('http://192.168.30.235:9999/rest/user/register',{'account':telephones,'pwd':pw1,'pwd2':pw2}).then(function(data){
                        if(data.data.code == '0'){
                            that.$set('toasttext','註冊成功');
                             that.$set('toastshow',true);
                        }else{
                            that.$set('toasttext','註冊失敗');
                             that.$set('toastshow',true);
                        }
                    },function(error){
                        //顯示返回的錯誤信息
                        that.$set('toasttext',String(error.status));
                        that.$set('toastshow',true);
                    })*/
                }
            })
            
        }
    }
}
</script>
<style>
.register-box{
    padding: 10px;
}
.pd05{
    margin-top: 5px;
}
.greenBtn{
    width: 173px;
    height: 30px;
    text-align: center;
    line-height: 30px;
    background: red;
    color: #fff;
    margin-top: 5px;
}
</style>

若點擊下一步,會提示「請完善表單」,由於驗證不經過;如果文本框得到焦點後失去焦點則會提示相應的錯誤信息;若內容填寫正確,則會提示驗證經過併發送相應的請求。

效果如圖


相關文章
相關標籤/搜索