VeeValidate 3.x 基本用法

VeeValidate 是一個(gè)輕量級(jí)的表單驗(yàn)證插件路媚,內(nèi)置了豐富的校驗(yàn)規(guī)則和錯(cuò)誤提示,而且非常容易擴(kuò)展殊轴,下面簡(jiǎn)單介紹它的使用方法

安裝
npm i vee-validate
# or
yarn add vee-validate
基本使用

template

<ValidationProvider class="form-item" name="email" tag="div" rules="required|email" v-slot="{ errors }">
  <label>郵箱</label>
  <input v-model="email" type="text" />
  <span class="ml-3">{{ errors[0] }}</span>
</ValidationProvider>
<ValidationProvider class="form-item" name="password" tag="div" rules="required|password:6,18" v-slot="{ errors }">
  <label>密碼</label>
  <input v-model="password" type="password" autocomplete="off" />
  <span class="ml-3">{{ errors[0] }}</span>
</ValidationProvider>

script

import { ValidationProvider } from 'vee-validate'

export default {
  name: 'HelloI18n',
  components: { ValidationProvider },
  data() {
    return {
      email: ''厌殉,
      password: ''
    }
  }
}

ValidationProvider會(huì)自動(dòng)在其子孫結(jié)點(diǎn)中查找具有v-model:value的輸入框并進(jìn)行校驗(yàn)踩叭。tag指定<ValidationProvider>渲染成的html元素磕潮。name指定字段的名字,通過name還可以配置字段名的多語言版本容贝,如果沒有為ValidationProvider提供name自脯,則字段名默認(rèn)為輸入框的id或者name屬性。rules指定校驗(yàn)規(guī)則斤富,應(yīng)用多個(gè)規(guī)則用|隔開膏潮,vee-validate內(nèi)置了許多校驗(yàn)規(guī)則,還可以通過extent自定義規(guī)則满力。

校驗(yàn)規(guī)則

一個(gè)項(xiàng)目中可能出現(xiàn)很多相同的輸入框焕参,為了讓校驗(yàn)規(guī)則在這些輸入框都能生效,可以在一個(gè)單獨(dú)文件中定義所有校驗(yàn)規(guī)則油额,然后在main.js中引入

utils/veevalidate.js

import { extend, localize } from 'vee-validate'
import { required, email, min, length, confirmed } from 'vee-validate/dist/rules'
import zh from 'vee-validate/dist/locale/zh_CN.json'
import en from 'vee-validate/dist/locale/en.json'
extend('email', email)

extend('min', min)
extend('required', required)

extend('length', length)

extend('confirmed', confirmed)

extend('password', {
  validate(value, { min, max }) {
    return value.length >= min && value.length <= max
  },
  params: ['min', 'max']
})
localize({
  'zh-CN': {
    names: {
      email: '郵箱',
      password: '密碼'
    },
    messages: {
      ...zh.messages,
      required: '請(qǐng)輸入{_field_}',
      email: '請(qǐng)輸入正確的郵箱格式',
      password: '密碼必須是6到18位'
    }
  },
  en: {
    names: {
      email: 'email',
      password: 'password'
    },
    messages: {
      ...en.messages,
      required: 'please input {_field_}',
      email: 'please input correct email',
      password: 'the password length should be 6 to 18'
    }
  }
})

localize('zh-CN')
自定義校驗(yàn)規(guī)則
extend('ruleName', rule)

第一個(gè)參數(shù)是規(guī)則名稱叠纷,第二個(gè)參數(shù)是規(guī)則的schema。如果希望在定義規(guī)則時(shí)同時(shí)定義錯(cuò)誤消息體潦嘶,可以像下面這樣寫

extend('required', {
  ...required,      // 官方自帶的校驗(yàn)規(guī)則
  message: '必填項(xiàng)!!!' // 自定義錯(cuò)誤消息 
})
傳參

自定義規(guī)則支持傳參涩嚣,如rules="required|password:6,18"表示應(yīng)用requiredpassword兩個(gè)規(guī)則,并向第二個(gè)規(guī)則傳遞了兩個(gè)參數(shù)掂僵,接收的參數(shù)需要在params進(jìn)行聲明

extend('password', {
  validate(value, { min, max }) {
    return value.length >= min && value.length <= max
  },
  params: ['min', 'max']
})
本地化

vee-validate提供localize方法設(shè)置語言環(huán)境

設(shè)置語言環(huán)境
import { localize } from 'vee-validate';

// Activate the Arabic locale.
localize('ar');

也可以在設(shè)置語言環(huán)境的同時(shí)加載該語境下的messages

import { localize } from 'vee-validate';
import ar from 'vee-validate/dist/locale/ar.json';

// Install and Activate the Arabic locale.
localize('ar', ar);
本地化字段名

默認(rèn)字段名是ValidationProvidername屬性航厚,可以通過names來配置其他語言版本

localize({
  'zh-CN': {
    names: {
      email: '郵箱',
      password: '密碼'
    }
  }
})
本地化錯(cuò)誤消息

默認(rèn)提示信息都是英文的,通過設(shè)置messages可以在切換語言后顯示對(duì)應(yīng)語言的錯(cuò)誤提示信息锰蓬。...zh.messages是加載vee-validate內(nèi)置的錯(cuò)誤消息幔睬。{_field_}是一個(gè)占位符,它會(huì)被ValidationProvidername屬性值所替代

import zh from 'vee-validate/dist/locale/zh_CN.json'
localize({
  'zh-CN': {
    messages: {
      ...zh.messages,
      required: '請(qǐng)輸入{_field_}',
      email: '請(qǐng)輸入正確的郵箱格式',
      password: '密碼必須是6到18位'
    }
  }
})
為每個(gè)字段設(shè)置錯(cuò)誤消息

vee-validate提供了fields選項(xiàng)芹扭,可以為某個(gè)字段的每一個(gè)規(guī)則定義不同錯(cuò)誤提示消息

localize({
  en: {
    fields: {
      password: {
        required: 'Password cannot be empty!',
        max: 'Are you really going to remember that?',
        min: 'Too few, you want to get doxed?'
      }
    }
  }
});
懶加載

如果要為不同語言構(gòu)建不同應(yīng)用版本麻顶,那么一次導(dǎo)入所有messages顯然不是很好的選擇,可以使用動(dòng)態(tài)導(dǎo)入方式代替

import { localize } from 'vee-validate';

function loadLocale(code) {
  return import(`vee-validate/dist/locale/${code}.json`).then(locale => {
    localize(code, locale);
  });
}
驗(yàn)證整個(gè)表單

在提交表單的時(shí)候需要對(duì)整個(gè)表單進(jìn)行驗(yàn)證冯勉,這個(gè)時(shí)候需要用到ValidationObserver組件

template

<ValidationObserver tag="form" ref="obs">
  <ValidationProvider class="form-item" name="email" tag="div" rules="required|email" v-slot="{ errors }">
    <label>郵箱</label>
    <input v-model="email" type="text" />
    <span class="ml-3">{{ errors[0] }}</span>
  </ValidationProvider>
  <ValidationProvider class="form-item" name="password" tag="div" rules="required|password:6,18" v-slot="{ errors }">
    <label>密碼</label>
    <input v-model="password" type="password" autocomplete="off" />
    <span class="ml-3">{{ errors[0] }}</span>
  </ValidationProvider>
</ValidationObserver>

script

async submit() {
  const isValid = await this.$refs.obs.validate()
  if (!isValid) {
    // 沒有通過校驗(yàn)
    return false
  }
  // 通過校驗(yàn)
},
觸發(fā)方式

vee-validate提供了四種觸發(fā)驗(yàn)證的方式澈蚌,默認(rèn)情況下用戶輸入時(shí)觸發(fā)。

  • Aggressive灼狰,輸入時(shí)觸發(fā)(默認(rèn))
  • Passive宛瞄,表單提交時(shí)觸發(fā)
  • Lazy,失去焦點(diǎn)(blur)或者更改(change)時(shí)觸發(fā)
  • Eager,AggressiveLazy 的組合份汗,當(dāng)輸入框失去焦點(diǎn)(blur)或者內(nèi)容更改(change)時(shí)觸發(fā)一次校驗(yàn)盈电,如果無效,進(jìn)入Aggressive模式杯活,直到輸入變?yōu)橛行?/li>
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末匆帚,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子旁钧,更是在濱河造成了極大的恐慌吸重,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,692評(píng)論 6 501
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件歪今,死亡現(xiàn)場(chǎng)離奇詭異嚎幸,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)寄猩,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,482評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門嫉晶,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人田篇,你說我怎么就攤上這事替废。” “怎么了泊柬?”我有些...
    開封第一講書人閱讀 162,995評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵椎镣,是天一觀的道長(zhǎng)。 經(jīng)常有香客問我彬呻,道長(zhǎng)衣陶,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,223評(píng)論 1 292
  • 正文 為了忘掉前任闸氮,我火速辦了婚禮,結(jié)果婚禮上教沾,老公的妹妹穿的比我還像新娘蒲跨。我一直安慰自己,他們只是感情好授翻,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,245評(píng)論 6 388
  • 文/花漫 我一把揭開白布或悲。 她就那樣靜靜地躺著,像睡著了一般堪唐。 火紅的嫁衣襯著肌膚如雪巡语。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,208評(píng)論 1 299
  • 那天淮菠,我揣著相機(jī)與錄音男公,去河邊找鬼。 笑死合陵,一個(gè)胖子當(dāng)著我的面吹牛枢赔,可吹牛的內(nèi)容都是我干的澄阳。 我是一名探鬼主播,決...
    沈念sama閱讀 40,091評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼踏拜,長(zhǎng)吁一口氣:“原來是場(chǎng)噩夢(mèng)啊……” “哼碎赢!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起速梗,我...
    開封第一講書人閱讀 38,929評(píng)論 0 274
  • 序言:老撾萬榮一對(duì)情侶失蹤肮塞,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后姻锁,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體峦嗤,經(jīng)...
    沈念sama閱讀 45,346評(píng)論 1 311
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,570評(píng)論 2 333
  • 正文 我和宋清朗相戀三年屋摔,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了烁设。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,739評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡钓试,死狀恐怖装黑,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情弓熏,我是刑警寧澤恋谭,帶...
    沈念sama閱讀 35,437評(píng)論 5 344
  • 正文 年R本政府宣布,位于F島的核電站挽鞠,受9級(jí)特大地震影響疚颊,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜信认,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,037評(píng)論 3 326
  • 文/蒙蒙 一材义、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧嫁赏,春花似錦其掂、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,677評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至攘乒,卻和暖如春贤牛,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背则酝。 一陣腳步聲響...
    開封第一講書人閱讀 32,833評(píng)論 1 269
  • 我被黑心中介騙來泰國(guó)打工殉簸, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,760評(píng)論 2 369
  • 正文 我出身青樓喂链,卻偏偏與公主長(zhǎng)得像返十,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子椭微,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,647評(píng)論 2 354