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 相关文章推荐
基于jquery扩展漂亮的下拉框可以二次修改
Nov 19 Javascript
jQuery结合ajax实现动态加载文本内容
May 19 Javascript
javascript省市级联功能实现方法实例详解
Oct 20 Javascript
js实现无缝滚动特效
Dec 20 Javascript
JS获取IE版本号与HTML设置IE文档模式的方法
Oct 09 Javascript
javascript滚轮控制模拟滚动条
Oct 19 Javascript
React-Native实现ListView组件之上拉刷新实例(iOS和Android通用)
Jul 11 Javascript
React组件中的this的具体使用
Feb 28 Javascript
配置一个vue3.0项目的完整步骤
Apr 26 Javascript
vue获取form表单的值示例
Oct 29 Javascript
JavaScript switch语句使用方法简介
Dec 30 Javascript
OpenLayers3实现地图鹰眼以及地图比例尺的添加
Sep 25 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数组函数序列之array_keys() - 获取数组键名
2011/10/30 PHP
php空间不支持socket但支持curl时recaptcha的用法
2011/11/07 PHP
ThinkPHP CURD方法之limit方法详解
2014/06/18 PHP
PHP+Ajax检测用户名或邮件注册时是否已经存在实例教程
2014/08/23 PHP
列举PHP的Yii 2框架的开发优势
2015/07/03 PHP
浅谈mysql_query()函数的返回值问题
2016/09/05 PHP
PHPstorm快捷键(分享)
2017/07/17 PHP
PHP微信企业号开发之回调模式开启与用法示例
2017/11/25 PHP
JavaScript call apply使用 JavaScript对象的方法绑定到DOM事件后this指向问题
2011/09/28 Javascript
jQuery EasyUI API 中文文档 - Spinner微调器使用
2011/10/21 Javascript
JavaScript面向对象程序设计三 原型模式(上)
2011/12/21 Javascript
jQuery+JSON+jPlayer实现QQ空间音乐查询功能示例
2013/06/17 Javascript
Node.js和PHP根据ip获取地理位置的方法
2014/03/14 Javascript
node+express+jade制作简单网站指南
2014/11/26 Javascript
jquery实现未经美化的简洁TAB菜单效果
2015/08/28 Javascript
微信小程序 教程之注册页面
2016/10/17 Javascript
Node.js批量给图片加水印的方法
2016/11/15 Javascript
Bootstrap禁用响应式布局的实现方法
2017/03/09 Javascript
Node.js Stream ondata触发时机与顺序的探索
2019/03/08 Javascript
vue项目创建并引入饿了么elementUI组件的步骤
2019/04/11 Javascript
vue-element-admin 菜单标签失效的解决方式
2019/11/12 Javascript
[43:58]DOTA2上海特级锦标赛C组败者赛 Newbee VS Archon第二局
2016/02/27 DOTA
python实现自动登录后台管理系统
2018/10/18 Python
解决python3运行selenium下HTMLTestRunner报错的问题
2018/12/27 Python
利用python脚本如何简化jar操作命令
2019/02/24 Python
python爬取基于m3u8协议的ts文件并合并
2019/04/26 Python
PyInstaller将Python文件打包为exe后如何反编译(破解源码)以及防止反编译
2020/04/15 Python
美国农场鲜花速递:The Bouqs
2018/07/13 全球购物
创建学习型党组织实施方案
2014/03/29 职场文书
小小商店教学反思
2014/04/27 职场文书
实习生工作证明范本
2014/09/14 职场文书
公司放假通知范文
2015/04/14 职场文书
导游词之镜泊湖
2019/12/09 职场文书
vue中data改变后让视图同步更新的方法
2021/03/29 Vue.js
如何有效防止sql注入的方法
2021/05/25 SQL Server
Python极值整数的边界探讨分析
2021/09/15 Python