欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue-validator(vue驗(yàn)證器)

 更新時(shí)間:2017年01月16日 14:17:31   作者:藝小晨  
本篇文章主要介紹了vue-validator(vue驗(yàn)證器),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧

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

github項(xiàng)目地址:https://github.com/vuejs/vue-validator

單獨(dú)使用vue-validator的方法見(jiàn)官方文檔,本文結(jié)合vue-router使用。

安裝驗(yàn)證器

不添加自定義驗(yàn)證器或者無(wú)需全局使用的公用驗(yàn)證器,在main.js中安裝驗(yàn)證器,使用 CommonJS 模塊規(guī)范, 需要顯式的使用 Vue.use() 安裝驗(yàn)證器組件。

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

與 vue-router 同時(shí)使用,必須在調(diào)用 router#map, router#start 等實(shí)例方法前安裝驗(yàn)證。

若要自定義驗(yàn)證器,建一個(gè)js文件,在該文件中安裝驗(yàn)證器組件。例如:validation.js

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

自定義驗(yàn)證器

官方提供的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

但是以上的不一定滿足我們的需求,這時(shí)就需要用到另一個(gè)全局api,用于注冊(cè)和獲取全局驗(yàn)證器。

Vue.validator( id, [definition] )

示例  定義validation.js  內(nèi)容如下

import Vue from 'vue'
import Validator from 'vue-validator'
Vue.use(Validator)
//自定義驗(yàn)證器
//添加一個(gè)簡(jiǎn)單的手機(jī)號(hào)驗(yàn)證 
//匹配0-9之間的數(shù)字,并且長(zhǎng)度是11位
Vue.validator('tel', function (val) {
 return /^[0-9]{11}$/.test(val)
});
//添加一個(gè)密碼驗(yàn)證
//匹配6-20位的任何字類字符,包括下劃線。與“[A-Za-z0-9_]”等效。
Vue.validator('passw', function (val) {
 return /^(\w){6,20}$/.test(val)
});

使用驗(yàn)證器

驗(yàn)證器語(yǔ)法

<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個(gè)字符</span>
   <span v-show="$validation.comment.maxlength">不得大于15個(gè)字符</span>
  </div>
 </validator>

默認(rèn)情況下,vue-validator 會(huì)根據(jù) validator 和 v-validate 指令自動(dòng)進(jìn)行驗(yàn)證。然而有時(shí)候我們需要關(guān)閉自動(dòng)驗(yàn)證,在有需要時(shí)手動(dòng)觸發(fā)驗(yàn)證。如果你不需要自動(dòng)驗(yàn)證,可以通過(guò) initial 屬性或 v-validate 驗(yàn)證規(guī)則來(lái)關(guān)閉自動(dòng)驗(yàn)證。如下:

<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個(gè)字符</span>
    <span v-show="$validation.comment.maxlength">不得大于15個(gè)字符</span>
   </div>
</validator>

Terminal 指令問(wèn)題

<validator name="test_validator">
  <!-- @invalid:valid的逆 ,表示驗(yàn)證不通過(guò) -->
  <input @invalid="passwInvalid" @valid="passwok" type="password" v-model='passw' id='passw' v-validate:passw="['passw']" detect-change="off" initial='off' placeholder='請(qǐng)輸入密碼'>
  <input @invalid="passwInvalid" @valid="passwok" type="password" v-model='passw2' id='passw2' v-validate:passw2="['passw']" detect-change="off" initial='off' placeholder='請(qǐng)輸入密碼'>
</validator>
<script>
//若是在main.js中導(dǎo)入 無(wú)需再次導(dǎo)入
//此處導(dǎo)入的是上面代碼的validation.js
import validator from '../validator/validation'
export default{
  data(){
    return{
      comment:'',
      passw:'',
      passw2:''
    }
  },
  methods:{
    passwInvalid(){
      alert('只能輸入6-20個(gè)字母、數(shù)字、下劃線');
    },
    passwok(){
      //alert('驗(yàn)證碼符合規(guī)范')
    }
  }
}
</script>

示例:用戶注冊(cè)驗(yàn)證

用了一個(gè)組件來(lái)顯示提示信息

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;
      }
    },
    //提示的內(nèi)容
    toasttext:{
      type:String,
      required: false,
      default:function(){
        return 'no message';
      }
    },
    //顯示的時(shí)間
    duration: {
      type: Number,
      default:3000,//默認(rèn)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>

注冊(cè)用戶:假如我們需要填寫(xiě)手機(jī)號(hào)和輸入兩次密碼

<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='請(qǐng)輸入手機(jī)號(hào)碼'>
      </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='請(qǐng)輸入密碼'>
      </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='請(qǐng)輸入密碼'>
      </div>
      <a class='greenBtn' v-on:click='register_user()'>下一步</a>
    </div>
    </validator>
  </div>
</template>
<script>
//導(dǎo)入validation.js 此處的validation.js就是上文中validation.js的內(nèi)容
import validator from '../validator/validation';
//導(dǎo)入顯示提示信息的組件
import Toast from '../components/toast.vue';
export default{  
  components: {
    //注冊(cè)組件
     Toast
   },
  data(){
    return{
      telphone:'',//電話號(hào)碼
      toastshow:false,//默認(rèn)不現(xiàn)實(shí)提示信息
      toasttext:'',//提示信息內(nèi)容
      passw1:'',//首次輸入密碼
      passw2:''//再次輸入密碼
    }
  },
  methods:{
    //手機(jī)號(hào)驗(yàn)證失敗時(shí)執(zhí)行的方法
    telonInvalid(){
      //設(shè)置提示信息內(nèi)容
      this.$set('toasttext','手機(jī)不正確');
      //顯示提示信息組件
      this.$set('toastshow',true);
    },
    //密碼驗(yàn)證失敗時(shí)執(zhí)行的方法
    passwInvalid(){
      this.$set('toasttext','只能輸入6-20個(gè)字母、數(shù)字、下劃線');
      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) {
          //驗(yàn)證無(wú)效
           that.$set('toasttext','請(qǐng)完善表單');
           that.$set('toastshow',true);
        }else{
           that.$set('toasttext','驗(yàn)證通過(guò)');
           that.$set('toastshow',true);
           //驗(yàn)證通過(guò)做注冊(cè)請(qǐng)求
           /*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','注冊(cè)成功');
               that.$set('toastshow',true);
            }else{
              that.$set('toasttext','注冊(cè)失敗');
               that.$set('toastshow',true);
            }
          },function(error){
            //顯示返回的錯(cuò)誤信息
            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>

若點(diǎn)擊下一步,會(huì)提示“請(qǐng)完善表單”,因?yàn)轵?yàn)證不通過(guò);若是文本框獲得焦點(diǎn)后失去焦點(diǎn)則會(huì)提示相應(yīng)的錯(cuò)誤信息;若內(nèi)容填寫(xiě)正確,則會(huì)提示驗(yàn)證通過(guò)并發(fā)送相應(yīng)的請(qǐng)求。

效果如圖

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue + typescript + video.js實(shí)現(xiàn) 流媒體播放 視頻監(jiān)控功能

    vue + typescript + video.js實(shí)現(xiàn) 流媒體播放 視頻監(jiān)控功能

    視頻才用流媒體,有后臺(tái)實(shí)時(shí)返回?cái)?shù)據(jù), 要支持flash播放, 所以需安裝對(duì)應(yīng)的flash插件。這篇文章主要介紹了vue + typescript + video.js 流媒體播放 視頻監(jiān)控,需要的朋友可以參考下
    2019-07-07
  • vue-cli配置flexible過(guò)程詳解

    vue-cli配置flexible過(guò)程詳解

    這篇文章主要介紹了vue-cli配置flexible過(guò)程詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2019-07-07
  • vue結(jié)合vue-electron創(chuàng)建應(yīng)用程序小結(jié)

    vue結(jié)合vue-electron創(chuàng)建應(yīng)用程序小結(jié)

    這篇文章主要介紹了vue結(jié)合vue-electron創(chuàng)建應(yīng)用程序,本文給大家介紹了安裝electron有兩種方式,兩種方式創(chuàng)建的項(xiàng)目結(jié)構(gòu)大不相同,需要的朋友可以參考下
    2024-03-03
  • antd+vue實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證循環(huán)屬性表單的思路

    antd+vue實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證循環(huán)屬性表單的思路

    今天通過(guò)本文給大家分享antd+vue實(shí)現(xiàn)動(dòng)態(tài)驗(yàn)證循環(huán)屬性表單的思路,代碼簡(jiǎn)單易懂,對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2021-09-09
  • 詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn))

    詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn))

    本篇文章主要介紹了詳解vue中點(diǎn)擊空白處隱藏div的實(shí)現(xiàn)(用指令實(shí)現(xiàn)),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-04-04
  • vue router下的html5 history在iis服務(wù)器上的設(shè)置方法

    vue router下的html5 history在iis服務(wù)器上的設(shè)置方法

    這篇文章主要介紹了vue router下的html5 history在iis服務(wù)器上的設(shè)置方法,需要的朋友參考下吧
    2017-10-10
  • VUE生命周期全面系統(tǒng)詳解

    VUE生命周期全面系統(tǒng)詳解

    Vue的生命周期就是vue實(shí)例從創(chuàng)建到銷毀的全過(guò)程,也就是new?Vue()?開(kāi)始就是vue生命周期的開(kāi)始。Vue?實(shí)例有?個(gè)完整的?命周期,也就是從開(kāi)始創(chuàng)建、初始化數(shù)據(jù)、編譯模版、掛載Dom?->?渲染、更新?->?渲染、卸載?等?系列過(guò)程,稱這是Vue的?命周期
    2022-07-07
  • 關(guān)于element的表單組件整理筆記

    關(guān)于element的表單組件整理筆記

    這篇文章主要給大家介紹了關(guān)于element的表單組件的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2021-02-02
  • 搭建vue3項(xiàng)目以及按需引入element-ui框架組件全過(guò)程

    搭建vue3項(xiàng)目以及按需引入element-ui框架組件全過(guò)程

    element是基于vue.js框架開(kāi)發(fā)的快速搭建前端的UI框架,下面這篇文章主要給大家介紹了關(guān)于搭建vue3項(xiàng)目以及按需引入element-ui框架組件的相關(guān)資料,文中通過(guò)圖文以及代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-02-02
  • vue添加class樣式實(shí)例講解

    vue添加class樣式實(shí)例講解

    在本文里我們給大家整理了關(guān)于vue添加class樣式實(shí)例,對(duì)此有興趣的朋友們可以學(xué)習(xí)參考下。
    2019-02-02

最新評(píng)論