Vue.js + Nuxt.js 項目中使用 Vee-validate 表單校驗

vee-validate 是爲 Vue.js 量身打造的表單校驗框架,容許您校驗輸入的內容並顯示對應的錯誤提示信息。它內置了不少常見的校驗規則,能夠組合使用多種校驗規則,大部分場景只須要配置就能實現開箱即用,還支持自定義正則表達式。並且支持 40 多種語言,對本地化、多語言支持很是友好。javascript

國內餓了麼團隊開源項目 Element UI 就用到了 vee-validatehtml

vee-validate官網:https://baianat.github.io/vee-validate/vue

1. 安裝

安裝 vee-validate 到項目中java

npm install vee-validate --save

2. 建立 vee-validate 插件

a. 建立插件

在 Nuxt.js 項目 plugins 目錄下建立 veevalidate.jsgit

b. 引入、配置 vee-validate

import Vue from 'vue'
import zhCN from 'vee-validate/dist/locale/zh_CN' // 引入本地化語言
import VeeValidate, { Validator } from 'vee-validate' // 引入 vee-validate

// 覆蓋默認錯誤信息提示
zhCN.messages.email = () => '請輸入正確的郵箱地址'

Vue.use(VeeValidate)

// 本地化
Validator.localize('zh_CN', zhCN)

3. 引入 vee-validate 到項目中

nuxt.config.js 中引入剛纔配置好的插件 veevalidate.jsgithub

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

4. 表單頁實現自定義錯誤提示、自定義檢驗規則

HTML 表單

<form action="">
  <van-cell-group>
    <van-field placeholder="請輸入有效郵箱" type="email" v-model="email" name="email"
      v-validate="'required|email'" :error-message="errors.first('email')" />
    <van-field placeholder="請輸入密碼" 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. 自定義錯誤提示信息

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

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

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

5. 效果截圖

轉載請註明出處: https://blog.givebest.cn/javascript/2019/04/20/vue.js-nuxt.js-use-vee-validate.html正則表達式

相關文章
相關標籤/搜索