引入:
npm install vee-validate --save
vue代碼:
import VeeValidate from 'vee-validate';import zh_CN from 'vee-validate/dist/locale/zh_CN'; //引入中文包,提示信息可以以中文形式顯示import { Validator } from 'vee-validate';Validator.addLocale(zh_CN); // 設置提示信息中文方式顯示const config = { errorBagName: 'errors', fieldsBagName: 'fields', delay: 100, locale: 'zh_CN', strict: true, enableAutoClasses: true, events: 'blur', inject: true};// 自定義提示信息const dictionary = { zh_CN: { messages: { ip: () => 'ip格式不正確😯 >.<' } }};Validator.updateDictionary(dictionary);// 自定義規則Validator.extend('qq', { messages: { zh_CN:field => 'qq號碼輸入不正確' }, validate: value => { return /^[1-9][0-9]{4,14}$/.test(value); }});Vue.use(VeeValidate, config); //一般插件都要use一下
使用
<label><span>ip:</span><input v-validate="'required|email'" name="email" type="text" v-model="ip"/></label><span v-show="errors.first('ip')">{{ errors.first('ip') }}</span>
注意 : name一定要寫,否則不會進行驗證
config配置信息
插件的一些功能可以自定義,需要編寫config,然后Vue.use(VeeValidate, config)來使用
一下為配置信息的意思(可能不全面)
errorBagName: 'erroers'
所有的錯誤信息都是放在這個里面的,如果名稱和頁面上的變量名字沖突,需要修改成其他的,當是errors.fist的時候,error就是字符串,當使用error.all()/error.collect()的時候就是數組
fieldsBagName: 'fields'
字段的名稱(標志)的對象,將在每個Vue的實例數據注入。如果在頁面上使用了ip的驗證,那么,可以通過如下獲取一個對象:
this.fileds.ip >> 獲取到的對象:{ dirty :true invalid:false pending:false pristine:false required:true touched:true untouched:false valid:true validated:true}
delay : 100 表示獲取輸入信息的時間
locale: ‘zh_CN' 驗證消息的默認語言。
strict: true 表示沒有設置規則的表單不進行驗證
classes (不懂)
events: 'blur|input' 默認是input|blur 就是在用戶輸入和表單失去焦點的時候都進行驗證,blue表示失去焦點的時候進行驗證
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。
新聞熱點
疑難解答