亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

VeeValidate 的使用場景以及配置詳解

2019-11-19 12:17:58
字體:
來源:轉載
供稿:網友

創建vue項目:

vue init webpack veecd ./vee npm run dev # oryarn run dev

安裝 VeeValidate

npm install vee-validate --save# oryarn add vee-validate --save

本文中使用的 VeeValidate 版本為 2.1.5

在 App.vue 中引入

import VeeValidate from 'vee-validate';Vue.use(VeeValidate);

例子

第一個測試例子

<template> <div class="test1"> <div>  <input  type="text"  name="nickname"  v-model="formData.nickname"  v-validate="'required|min:3|max:10'"  >  <p>{{errors.first('nickname')}}</p> </div> <div>  <button @click="handleSubmit">Submit</button> </div> </div></template><script> export default { name: "test1", data() {  return {  formData: {   nickname: '',   password: '',  }  } }, methods: {  handleSubmit() {  this.$validator.validate()   .then((valid) => {   if (true === valid) {    console.log('驗證通過');   } else {    console.log(this.$validator.errors.all());   }   })  } } }</script><style scoped lang="css"> .test1 { width: 900px; margin: 0 auto; }</style>

更多配置請參考官網!

我們只是用些常用配置和常用的驗證!

中文配置

全局配置

import VeeValidate, {Validator} from 'vee-validate';import zh_CN from 'vee-validate/dist/locale/zh_CN';Vue.use(VeeValidate, { dictionary: { zh_CN: zh_CN }});Validator.localize('zh_CN');

這樣就可以使用中文提示了!

自定義錯誤提示

<template> <div class="test2"> <div><input type="text" v-model="formData.nickname" data-vv-name="nickname" v-validate="'required|min:3|max:10'"> </div> <div>{{errors.first('nickname')}}</div> <div><input type="text" v-model="formData.password" data-vv-name="password" v-validate="'required|min:5|max:200'"> </div> <div>{{errors.first('password')}}</div> <div>  <button @click="handleSubmit">Submit</button> </div> </div></template><script> const validate = { custom: {  nickname: {  required: () => '昵稱不得為空', //寫法1  min: "昵稱不得小于3個字符", //寫法2  max: () => '昵稱不得大于10個字符'  },  password: {  required: () => '密碼不得為空',  min: "密碼不得小于5個字符",  max: () => '密碼不得大于200個字符'  } }, }; export default { name: "test2", data() {  return {  formData: {   nickname: '',   password: '',  }  } }, methods: {  handleSubmit() {  this.$validator.validate()   .then((valid) => {   if (true === valid) {    console.log('驗證通過');   } else {    console.log(this.$validator.errors.all());   }   })  } }, mounted() {  this.$validator.localize('zh_CN', validate); } }</script>

自定義驗證規則

<template> <div class="test2"> <div><input type="text" v-model="formData.nickname" data-vv-name="nickname" v-validate="'required|min:3|max:10'"> </div> <div>{{errors.first('nickname')}}</div> <div><input type="text" v-model="formData.password" data-vv-name="password" v-validate="'required|min:5|max:200'"> </div> <div>{{errors.first('password')}}</div> <div><input type="text" v-model="formData.re_password" data-vv-name="re_password"    v-validate="'required|confirm'"> </div> <div>{{errors.first('re_password')}}</div> <div><input type="text" v-model="formData.mobile" data-vv-name="mobile" v-validate="'required|mobile'"> </div> <div>{{errors.first('mobile')}}</div> <div>  <button @click="handleSubmit">Submit</button> </div> </div></template><script> const validate = { custom: {  nickname: {  required: () => '昵稱不得為空', //寫法1  min: "昵稱不得小于3個字符", //寫法2  max: () => '昵稱不得大于10個字符'  },  password: {  required: () => '密碼不得為空',  min: "密碼不得小于5個字符",  max: () => '密碼不得大于200個字符'  },  re_password: {  required: () => '請再次輸入密碼!',  },  mobile: {  required: () => '請輸入手機號碼!',  } }, }; export default { name: "test3", data() {  return {  formData: {   nickname: '',   password: '',   re_password: '',   mobile: ''  }  } }, methods: {  handleSubmit() {  this.$validator.validate()   .then((valid) => {   if (true === valid) {    console.log('驗證通過');   } else {    console.log(this.$validator.errors.all());   }   })  } }, mounted() {  this.$validator.localize('zh_CN', validate);  this.$validator.extend('mobile', {  getMessage: field => '手機號有誤',  validate: value => {   return /^((13|14|15|17|18)[0-9]{1}/d{8})$/.test(value)  }  })  this.$validator.extend('confirm', {  getMessage: field => '兩次密碼輸入不一致',  validate: value => {   return value === this.formData.password  }  }) } }</script>

顯示第一個錯誤!

有時候我們需要在彈出層中提示用戶 所以要顯示第一個錯誤

this.$validator.errors.items[0].msg

例子 發驗證碼和注冊!

這個例子中發驗證碼是一個驗證 注冊又是一個驗證 所以有點意義!

在發送驗證碼的時候需要驗證手機號碼和圖形驗證碼 注冊的時候需要驗證除圖形驗證碼之外的數據

亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

国产精品爽黄69| 日本欧美爱爱爱| 日韩国产欧美精品一区二区三区| 97精品国产97久久久久久春色| 欧美日韩精品在线播放| 欧美性69xxxx肥| 91精品成人久久| 日本欧美一二三区| 亚洲毛茸茸少妇高潮呻吟| 欧美亚洲国产成人精品| 久久亚洲综合国产精品99麻豆精品福利| 精品久久久久久中文字幕一区奶水| 97视频在线观看免费高清完整版在线观看| 欧美午夜xxx| 欧美激情在线观看视频| www国产亚洲精品久久网站| 一区二区三区美女xx视频| 亚洲色图偷窥自拍| 黄色成人在线播放| 日韩中文字幕在线视频| 久久久电影免费观看完整版| 久久久久久久电影一区| 国产精品91视频| 国产精品一区二区女厕厕| 欧美亚洲免费电影| 久久国产精品电影| 日韩精品视频在线| 8050国产精品久久久久久| 久久久久久12| 91av视频在线免费观看| 久久在线免费视频| 欧美人在线视频| 91精品啪在线观看麻豆免费| 91精品视频专区| 最新国产成人av网站网址麻豆| 亚洲精品免费av| 国产精品视频yy9099| 午夜精品一区二区三区av| 国产精品久久久久久久9999| 国产精品入口免费视频一| 精品国产一区二区在线| 欧美小视频在线观看| 亚洲欧洲免费视频| 午夜精品久久17c| 日韩成人在线网站| 欧美日韩成人网| 亚洲国产日韩欧美在线99| 青青草原一区二区| 精品久久久久久久久国产字幕| 久久久久久久久中文字幕| 91在线观看欧美日韩| 国产精品69久久久久| 国产精品免费看久久久香蕉| 在线精品国产成人综合| 97人人模人人爽人人喊中文字| 久久久成人精品| 亚洲人成在线电影| 中文字幕久热精品在线视频| 欧美丰满少妇xxxxx做受| 久久国产加勒比精品无码| 国内精品小视频| 成人亲热视频网站| 亚洲九九九在线观看| 欧美日韩国产成人在线| 亚洲精品国产精品国自产在线| 日韩欧美在线一区| 欧美视频在线观看免费| 亚洲免费视频网站| 国产精品香蕉国产| 中文字幕成人精品久久不卡| 中文字幕日韩av综合精品| 亚洲跨种族黑人xxx| 欧洲成人性视频| 国产美女91呻吟求| 青青青国产精品一区二区| 亚洲国产成人精品电影| 91高清在线免费观看| 91久久在线观看| 成人午夜两性视频| 国产精品香蕉av| 狠狠操狠狠色综合网| www.国产精品一二区| 久久视频在线播放| 日韩电影视频免费| 自拍偷拍亚洲欧美| 日韩成人网免费视频| 日本高清视频精品| 日韩经典中文字幕| 欧美一级高清免费播放| 日韩电影中文字幕在线| 亚洲精品不卡在线| 亚洲三级黄色在线观看| www日韩欧美| 日韩精品极品毛片系列视频| 国内自拍欧美激情| 亚洲人成在线免费观看| 91精品中国老女人| 久久成人国产精品| 91精品91久久久久久| 日韩av色综合| 国产精品99久久久久久白浆小说| 亚洲综合日韩在线| 国产91在线视频| 欧美日韩国产在线看| 精品女同一区二区三区在线播放| 欧美色视频日本版| 亚洲欧美制服丝袜| 欧美在线视频播放| 久久精品国产亚洲| 亚洲欧洲av一区二区| 国产色婷婷国产综合在线理论片a| 亚洲欧美国产精品| 91亚洲国产精品| 日韩av在线网站| 国产亚洲a∨片在线观看| 亚洲91精品在线观看| 精品视频久久久久久久| 日韩成人在线网站| 97国产精品视频人人做人人爱| 亚洲美女免费精品视频在线观看| 欧美极品美女电影一区| 国产精品亚洲网站| 国产不卡av在线免费观看| 国产精品情侣自拍| 午夜精品久久17c| 亚洲欧美国产精品va在线观看| 97在线视频免费看| 日韩av大片免费看| 国产欧美va欧美va香蕉在| 亚洲精品久久久久中文字幕二区| 亚洲欧洲黄色网| 欧美成人免费播放| 国产精品久久久久久久久粉嫩av| 中文字幕少妇一区二区三区| 色婷婷综合成人av| 久久久久久尹人网香蕉| 大伊人狠狠躁夜夜躁av一区| 欧美日韩国产影院| 91视频国产一区| 国产99久久精品一区二区永久免费| 亚洲美女在线看| 亚洲精品国产综合区久久久久久久| 亚洲人成77777在线观看网| 91免费在线视频网站| 日韩视频―中文字幕| 亚洲人成免费电影| 97免费视频在线播放| 国产视频精品xxxx| 国产成人精品在线观看| 欧美日韩在线免费| 国产精品成人播放| 久久久久中文字幕2018| 亚洲综合大片69999| 欧美中文在线观看| 不卡av在线播放| 久久久99免费视频| 国产免费久久av| 国产亚洲精品va在线观看| 亚洲aⅴ男人的天堂在线观看| 欧洲美女免费图片一区| 亚洲国产日韩精品在线| 亚洲精品久久久久久下一站| 欧美午夜视频一区二区| 欧美影院久久久|