這篇文章給大家分享的是有關(guān)vue-validator怎么用的內(nèi)容。小編覺得挺實(shí)用的,因此分享給大家做個(gè)參考,一起跟隨小編過來看看吧。
寶安網(wǎng)站制作公司哪家好,找創(chuàng)新互聯(lián)!從網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開發(fā)、APP開發(fā)、成都響應(yīng)式網(wǎng)站建設(shè)等網(wǎng)站項(xiàng)目制作,到程序開發(fā),運(yùn)營(yíng)維護(hù)。創(chuàng)新互聯(lián)從2013年成立到現(xiàn)在10年的時(shí)間,我們擁有了豐富的建站經(jīng)驗(yàn)和運(yùn)維經(jīng)驗(yàn),來保證我們的工作的順利進(jìn)行。專注于網(wǎng)站建設(shè)就選創(chuàng)新互聯(lián)。
官方文檔:http://vuejs.github.io/vue-validator/zh-cn/index.html
github項(xiàng)目地址:https://github.com/vuejs/vue-validator
單獨(dú)使用vue-validator的方法見官方文檔,本文結(jié)合vue-router使用。
安裝驗(yàn)證器
不添加自定義驗(yàn)證器或者無需全局使用的公用驗(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)證器語法
<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)證,可以通過 initial 屬性或 v-validate 驗(yàn)證規(guī)則來關(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 指令問題
<validator name="test_validator"> <!-- @invalid:valid的逆 ,表示驗(yàn)證不通過 --> <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)入 無需再次導(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è)組件來顯示提示信息
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è)用戶:假如我們需要填寫手機(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)證無效 that.$set('toasttext','請(qǐng)完善表單'); that.$set('toastshow',true); }else{ that.$set('toasttext','驗(yàn)證通過'); that.$set('toastshow',true); //驗(yàn)證通過做注冊(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)證不通過;若是文本框獲得焦點(diǎn)后失去焦點(diǎn)則會(huì)提示相應(yīng)的錯(cuò)誤信息;若內(nèi)容填寫正確,則會(huì)提示驗(yàn)證通過并發(fā)送相應(yīng)的請(qǐng)求。
效果如圖
感謝各位的閱讀!關(guān)于“vue-validator怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,讓大家可以學(xué)到更多知識(shí),如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到吧!
當(dāng)前文章:vue-validator怎么用
標(biāo)題鏈接:http://redsoil1982.com.cn/article8/gpjjip.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供品牌網(wǎng)站建設(shè)、網(wǎng)站制作、營(yíng)銷型網(wǎng)站建設(shè)、手機(jī)網(wǎng)站建設(shè)、小程序開發(fā)、外貿(mào)建站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)