vee-validate 是为 vue.js 量身打造的表单校验框架, 允许您校验输入的内容并显示对应的错误提示信息. 它内置了很多常见的校验规则, 可以组合使用多种校验规则, 大部分场景只需要配置就能实现开箱即用, 还支持自定义正则表达式. 而且支持 40 多种语言, 对本地化, 多语言支持非常友好.
国内饿了么团队开源项目 Element UI 就用到了 vee-validate.
vee-validate 官网: https://baianat.github.io/vee-validate/
1. 安装
安装 vee-validate 到项目中
NPM install vee-validate --save
2. 创建 vee-validate 插件
a. 创建插件
在 Nuxt.JS 项目 plugins 目录下创建 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
- // 覆盖默认错误信息提示
- zhCN.messages.email = () => '请输入正确的邮箱地址'
- Vue.use(VeeValidate)
- // 本地化
- Validator.localize('zh_CN', zhCN)
3. 引入 vee-validate 到项目中
在 nuxt.config.JS 中引入刚才配置好的插件 veevalidate.JS
- /*
- ** 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://www.cnblogs.com/givebest/p/10740644.html