Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验
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 多種語(yǔ)言,對(duì)本地化、多語(yǔ)言支持非常友好。
國(guó)內(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 --save2. 創(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. 效果截圖
轉(zhuǎn)載請(qǐng)注明出處: https://blog.givebest.cn/javascript/2019/04/20/vue.js-nuxt.js-use-vee-validate.html
轉(zhuǎn)載于:https://www.cnblogs.com/givebest/p/10740644.html
總結(jié)
以上是生活随笔為你收集整理的Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: MySQL配置文件配置
- 下一篇: 基于vue+mint-ui的mobile