您好,登录后才能下订单哦!
小编给大家分享一下Vue.js+Nuxt.js项目中如何使用Vee-validate表单校验,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
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. 效果截图
以上是“Vue.js+Nuxt.js项目中如何使用Vee-validate表单校验”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。