Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验


Posted in Javascript onApril 22, 2019

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 表单校验

总结

以上所述是小编给大家介绍的Vue.js + Nuxt.js 项目中使用 Vee-validate 表单校验 ,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

Javascript 相关文章推荐
javascript 24小时弹出一次的代码(利用cookies)
Sep 03 Javascript
Javascript Ajax异步读取RSS文档具体实现
Dec 12 Javascript
利用JS生成博文目录及CSS定制博客
Feb 10 Javascript
全面解析Bootstrap中scrollspy(滚动监听)的使用方法
Jun 06 Javascript
JS判断鼠标进入容器的方向与window.open新窗口被拦截的问题
Dec 23 Javascript
jQuery实现加入收藏夹功能(主流浏览器兼职)
Dec 24 Javascript
AngularJS使用ng-repeat遍历二维数组元素的方法详解
Nov 11 Javascript
webpack实用小功能介绍
Jan 02 Javascript
解决在vue项目中,发版之后,背景图片报错,路径不对的问题
Mar 06 Javascript
使用vue-cli3 创建vue项目并配置VS Code 自动代码格式化 vue语法高亮问题
May 14 Javascript
ant design实现圈选功能
Dec 17 Javascript
JS如何判断对象是否包含某个属性
Aug 29 Javascript
vue 项目build错误异常的解决方法
Apr 22 #Javascript
js实现web调用摄像头 js截取视频画面
Apr 21 #Javascript
今天,小程序正式支持 SVG
Apr 20 #Javascript
详解Vue中组件的缓存
Apr 20 #Javascript
Node.js折腾记一:读指定文件夹,输出该文件夹的文件树详解
Apr 20 #Javascript
优雅地使用loading(推荐)
Apr 20 #Javascript
详解JavaScript的数据类型以及数据类型的转换
Apr 20 #Javascript
You might like
PHP n个不重复的随机数生成代码
2009/06/23 PHP
PHP UTF8编码内的繁简转换类
2009/07/20 PHP
PHP取进制余数函数代码
2012/01/19 PHP
百万级别知乎用户数据抓取与分析之PHP开发
2015/09/28 PHP
jQuery截取指定长度字符串的实现原理及代码
2014/07/01 Javascript
在HTML代码中使用JavaScript代码的例子
2014/10/16 Javascript
jquery.picsign图片标注组件实例详解
2018/02/02 jQuery
vue如何在自定义组件中使用v-model
2018/05/14 Javascript
vue的style绑定background-image的方式和其他变量数据的区别详解
2018/09/03 Javascript
react+antd 递归实现树状目录操作
2020/11/02 Javascript
python实现提取百度搜索结果的方法
2015/05/19 Python
mysql 之通过配置文件链接数据库
2017/08/12 Python
Python 3.x 安装opencv+opencv_contrib的操作方法
2018/04/02 Python
在cmd命令行里进入和退出Python程序的方法
2018/05/12 Python
Windows下安装Scrapy
2018/10/17 Python
用python求一个数组的和与平均值的实现方法
2019/06/29 Python
python opencv对图像进行旋转且不裁剪图片的实现方法
2019/07/09 Python
Python队列RabbitMQ 使用方法实例记录
2019/08/05 Python
python如何实现单链表的反转
2020/02/10 Python
css和css3弹性盒模型实现元素宽度(高度)自适应
2019/05/15 HTML / CSS
巴基斯坦电子产品购物网站:Home Shopping
2017/09/14 全球购物
澳大利亚实惠时尚女装商店:Katies
2019/06/16 全球购物
英国在线定做百叶窗网站:Make My Blinds
2020/08/17 全球购物
路德维希•贝克(LUDWIG BECK)中文官网:德国大型美妆百货
2020/09/19 全球购物
大专生自我鉴定范文
2013/10/01 职场文书
综合素质的自我鉴定
2013/10/07 职场文书
创先争优承诺书范文
2014/03/31 职场文书
交通事故调解协议书
2014/04/16 职场文书
小学语文教研活动总结
2014/07/01 职场文书
八月一日观后感
2015/06/10 职场文书
2016新年年会主持词
2015/07/06 职场文书
雨雪天气温馨提示
2015/07/15 职场文书
标枪加油稿
2015/07/22 职场文书
交通安全主题班会
2015/08/12 职场文书
2016年119消防宣传日活动总结
2016/04/05 职场文书
Python Pygame实战之塔防游戏的实现
2022/03/17 Python