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)置了很多常見(jiàn)的校驗(yàn)規(guī)則,可以組合使用多種校驗(yàn)規(guī)則,大部分場(chǎng)景只需要配置就能實(shí)現(xiàn)開(kāi)箱即用,還支持自定義正則表達(dá)式。而且支持 40 多種語(yǔ)言,對(duì)本地化、多語(yǔ)言支持非常友好。
國(guó)內(nèi)餓了么團(tuán)隊(duì)開(kāi)源項(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' // 引入本地化語(yǔ)言
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. 表單頁(yè)實(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: '密碼長(zhǎng)度在7-26個(gè)字符', // 覆蓋 password 字段的 min 規(guī)則默認(rèn)信息提示
max: '密碼長(zhǎng)度在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. 效果截圖

總結(jié)
以上所述是小編給大家介紹的Vue.js + Nuxt.js 項(xiàng)目中使用 Vee-validate 表單校驗(yàn) ,希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!
如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!
相關(guān)文章
vue3在router中使用store報(bào)錯(cuò)的完美解決方案
這篇文章主要介紹了vue3在router中使用store報(bào)錯(cuò)解決方案,就是需要在實(shí)例化一下,因?yàn)樵诰幾grouter的時(shí)候pinia還未被實(shí)例化,文中補(bǔ)充介紹了vue3中router和store詳細(xì)使用教程方法,感興趣的朋友一起看看吧2023-11-11
Vue中一個(gè)組件調(diào)用其他組件的方法詳解(非父子組件)
vue中最常見(jiàn)子父組件產(chǎn)值,大家一定都很熟悉,最近項(xiàng)目中碰到非父組件中調(diào)用子組件方法的問(wèn)題,這篇文章主要給大家介紹了關(guān)于Vue中一個(gè)組件調(diào)用其他組件的方法(非父子組件),需要的朋友可以參考下2022-10-10
如何在vue3+ts項(xiàng)目中使用query和params傳參
Vue3中的路由傳參有兩種方式:query和params,下面這篇文章主要給大家介紹了關(guān)于如何在vue3+ts項(xiàng)目中使用query和params傳參的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-04-04
Vue組件簡(jiǎn)易模擬實(shí)現(xiàn)購(gòu)物車
這篇文章主要為大家詳細(xì)介紹了Vue組件簡(jiǎn)易模擬實(shí)現(xiàn)購(gòu)物車,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12
vue封裝echarts組件,數(shù)據(jù)動(dòng)態(tài)渲染方式
這篇文章主要介紹了vue封裝echarts組件,數(shù)據(jù)動(dòng)態(tài)渲染方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-12-12
vue單文件組件lint error自動(dòng)fix與styleLint報(bào)錯(cuò)自動(dòng)fix詳解
這篇文章主要給大家介紹了關(guān)于vue單文件組件lint error自動(dòng)fix與styleLint報(bào)錯(cuò)自動(dòng)fix的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-01-01
vue3 onMounted異步函數(shù)同步請(qǐng)求async/await實(shí)現(xiàn)
這篇文章主要為大家介紹了vue3 onMounted初始化數(shù)據(jù)異步函數(shù)/同步請(qǐng)求async/await實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-07-07
Vue3 組件間通信之mitt實(shí)現(xiàn)任意組件間通信的步驟
mitt 主要有4個(gè)API:emit(觸發(fā)某個(gè)事件)、on(綁定事件)、off(解綁某個(gè)事件)、all(獲取所有綁定的事件),這篇文章主要介紹了Vue3 組件間通信之mitt實(shí)現(xiàn)任意組件間通信,需要的朋友可以參考下2024-05-05
vue關(guān)于this.$refs.tabs.refreshs()刷新組件方式
這篇文章主要介紹了vue關(guān)于this.$refs.tabs.refreshs()刷新組件方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03

