溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

Vue.js+Nuxt.js項(xiàng)目中如何使用Vee-validate表單校驗(yàn)

發(fā)布時(shí)間:2021-08-10 13:24:40 來源:億速云 閱讀:234 作者:小新 欄目:web開發(fā)

小編給大家分享一下Vue.js+Nuxt.js項(xiàng)目中如何使用Vee-validate表單校驗(yàn),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

vee-validate 是為 Vue.js 量身打造的表單校驗(yàn)框架,允許您校驗(yàn)輸入的內(nèi)容并顯示對(duì)應(yīng)的錯(cuò)誤提示信息。它內(nèi)置了很多常見的校驗(yàn)規(guī)則,可以組合使用多種校驗(yàn)規(guī)則,大部分場(chǎng)景只需要配置就能實(shí)現(xiàn)開箱即用,還支持自定義正則表達(dá)式。而且支持 40 多種語言,對(duì)本地化、多語言支持非常友好。

國內(nèi)餓了么團(tuán)隊(duì)開源項(xiàng)目 Element UI 就用到了 vee-validate 。

vee-validate 官網(wǎng):https://baianat.github.io/vee-validate/

1. 安裝

安裝 vee-validate 到項(xiàng)目中

npm install vee-validate --save

2. 創(chuàng)建 vee-validate 插件

a. 創(chuàng)建插件

在 Nuxt.js 項(xiàng)目 plugins 目錄下創(chuàng)建 veevalidate.js 。

b. 引入、配置 vee-validate

import Vue from 'vue'
import zhCN from 'vee-validate/dist/locale/zh_CN' // 引入本地化語言
import VeeValidate, { Validator } from 'vee-validate' // 引入 vee-validate
// 覆蓋默認(rèn)錯(cuò)誤信息提示
zhCN.messages.email = () => '請(qǐng)輸入正確的郵箱地址'
Vue.use(VeeValidate)
// 本地化
Validator.localize('zh_CN', zhCN)

3. 引入 vee-validate 到項(xiàng)目中

在 nuxt.config.js 中引入剛才配置好的插件 veevalidate.js

/*
** Plugins to load before mounting the App
*/
plugins: [
  '@/plugins/veevalidate'
],

4. 表單頁實(shí)現(xiàn)自定義錯(cuò)誤提示、自定義檢驗(yàn)規(guī)則

HTML 表單

<form action="">
 <van-cell-group>
  <van-field placeholder="請(qǐng)輸入有效郵箱" type="email" v-model="email" name="email"
   v-validate="'required|email'" :error-message="errors.first('email')" />
  <van-field placeholder="請(qǐng)輸入密碼" v-model="password" type="password" name="password"
   v-validate="{ min: 3, max: 16, regex: regexps.password }" :error-message="errors.first('password')">
  </van-field>
 </van-cell-group>
</form>

JS

a. 自定義錯(cuò)誤提示信息

// 自定義錯(cuò)誤信息提示
const validateDict = {
 custom: {
  email: {
   required: '請(qǐng)輸入電子郵箱', // 覆蓋 email 字段的 required 規(guī)則默認(rèn)信息提示
   email: '請(qǐng)輸入有效的電子郵箱地址' // 覆蓋 email 字段的 email 規(guī)則默認(rèn)信息提示
  },
  password: {
   min: '密碼長度在7-26個(gè)字符', // 覆蓋 password 字段的 min 規(guī)則默認(rèn)信息提示
   max: '密碼長度在7-26個(gè)字符', // 覆蓋 password 字段的 max 規(guī)則默認(rèn)信息提示
   regex: '需包含大寫字母、小寫字母、數(shù)字、特殊字符中任意三項(xiàng)' // 覆蓋 email 字段的 regex 規(guī)則默認(rèn)信息提示
  }
 }
}

b. Vue 中覆蓋默認(rèn)配置,使用自定義提示信息

data () {
 regexps: {
  password: new RegExp('') // 密碼檢驗(yàn)自定義正則表達(dá)式
 },
},
created() {
 this.$validator.localize('zh_CN', validateDict)
},

5. 效果截圖

Vue.js+Nuxt.js項(xiàng)目中如何使用Vee-validate表單校驗(yàn)

以上是“Vue.js+Nuxt.js項(xiàng)目中如何使用Vee-validate表單校驗(yàn)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI