使用mixins实现elementUI表单全局验证的解决方法


Posted in Javascript onApril 02, 2019

使用ElementUi搭建框架的时候,大家应该都有考虑过怎么做全局验证,毕竟复制粘贴什么的是最烦了,这里分享下个人的解决方法。

验证规则
分析规则

一般验证规则,主要是是否必填,不为空,以及参数类型的验证。

基于这个条件,我们开始找找思路, 单个字段的验证是这样的:

name: {
 required: 是否必填,
 validator: 自定义规则,
 message: 失败提示消息(非自定义时触发),
 trigger: 触发方式
}

循环实现

固定的规则。当一个东西固定之后,那必然是可以重复使用的,并且可以快速生成,我们可以用循环来实现它。

但是用循环来实现,我们则需要一个数据规则。

定义数据规则

分析下需要的字段,大概就是以下几种,其他的可以根据自身的需求去增加:

  • 验证的字段名 label
  • 验证的值 value
  • 验证的类型 type
  • 是否必填 required
  • 自定义规则 rules

那最终我们得到的是这样一个字段配置列表:

fieldList: [
   {label: '账号', value: 'account', type: 'input', required: true},
   {label: '密码', value: 'password', type: 'password', required: true},
   {label: '昵称', value: 'name', type: 'input', required: true},
   {label: '性别', value: 'sex', type: 'select', list: 'sexList', required: true},
   {label: '头像', value: 'avatar', type: 'input'},
   {label: '手机号码', value: 'phone', type: 'input'},
   {label: '微信', value: 'wechat', type: 'input'},
   {label: 'QQ', value: 'qq', type: 'input'},
   {label: '邮箱', value: 'email', type: 'input'},
   {label: '状态', value: 'status', type: 'select', list: 'statusList', required: true}
  ]

form完整的字段配置建议参考:

// 表单相关
  formInfo: {
  ref: null,
  data: {
   id: '', // *唯一ID
   account: '', // *用户账号
   password: '', // *用户密码
   name: '', // *用户昵称
   type: 2, // *用户类型: 0: 手机注册 1: 论坛注册 2: 管理平台添加
   sex: 0, // *性别: 0:男 1:女
   avatar: '', // 头像
   phone: '', // 手机号码
   wechat: '', // 微信
   qq: '', // qq
   email: '', // 邮箱
   status: 1 // *状态: 0:停用,1:启用(默认为1)',
   // create_user: '', // 创建人
   // create_time: '', // 创建时间
   // update_user: '', // 修改人
   // update_time: '' // 修改时间
  },
  fieldList: [
   {label: '账号', value: 'account', type: 'input', required: true},
   {label: '密码', value: 'password', type: 'password', required: true},
   {label: '昵称', value: 'name', type: 'input', required: true},
   {label: '性别', value: 'sex', type: 'select', list: 'sexList', required: true},
   {label: '头像', value: 'avatar', type: 'input'},
   {label: '手机号码', value: 'phone', type: 'input'},
   {label: '微信', value: 'wechat', type: 'input'},
   {label: 'QQ', value: 'qq', type: 'input'},
   {label: '邮箱', value: 'email', type: 'input'},
   {label: '状态', value: 'status', type: 'select', list: 'statusList', required: true}
  ],
  rules: {},
  labelWidth: '120px'
  }

实现验证方法

  • 循环字段列表,根据type判断是提示选择不能为空,还是输入不能为空
  • 如果字段必填,则根据是否有自定义验证去生成验证规则
  • 字段非必填,有自定义规则生成验证
// 初始化验证数据
 _initRules (formInfo) {
  const obj = {},
  fieldList = formInfo.fieldList
  // 循环字段列表
  for (let item of fieldList) {
  let type = item.type === 'select' ? '选择' : '输入'

  if (item.required) {
   if (item.rules) {
   obj[item.value] = {
    required: item.required,
    validator: item.rules,
    trigger: 'blur'
   }
   } else {
   obj[item.value] = {
    required: item.required,
    message: '请' + type + item.label,
    trigger: 'blur'
   }
   }
  } else if (item.rules) {
   obj[item.value] = {
   validator: item.rules,
   trigger: 'blur'
   }
  }
  }
  formInfo.rules = obj
 }

怎么配置到全局

  • 通过mixin配置,然后在页面中使用(个人使用的是mixin)
  • 配置为全局方法在页面中调用
  • 挂在到vue实例上,通过this即可访问

最后

在项目的系统管理模块中可以看到示例代码:

项目地址

项目代码地址

总结

以上所述是小编给大家介绍的使用mixins实现elementUI表单的全局验证的解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
JQuery 学习笔记 选择器之六
Jul 23 Javascript
jquery及原生js获取select下拉框选中的值示例
Oct 25 Javascript
JavaScript学习笔记之基础语法
Jan 22 Javascript
jQuery获取当前点击的对象元素(实现代码)
May 19 Javascript
vue2.0+webpack环境的构造过程
Nov 08 Javascript
JavaScript正则表达式校验与递归函数实际应用实例解析
Aug 04 Javascript
js中this的指向问题归纳总结
Nov 28 Javascript
JavaScript实现的鼠标跟随特效示例【2则实例】
Dec 22 Javascript
js+HTML5 canvas 实现简单的加载条(进度条)功能示例
Jul 16 Javascript
vue在图片上传的时候压缩图片
Nov 18 Vue.js
element-ui点击查看大图的方法示例
Dec 14 Javascript
详解JSON.parse和JSON.stringify用法
Feb 18 Javascript
移动端自适应flexible.js的使用方法(不用三大框架,仅写一个单html页面使用)推荐
Apr 02 #Javascript
基于vue实现web端超大数据量表格的卡顿解决
Apr 02 #Javascript
基于AngularJS拖拽插件ngDraggable.js实现拖拽排序功能
Apr 02 #Javascript
详解vue后台系统登录态管理
Apr 02 #Javascript
微信小程序实现人脸识别登陆的示例代码
Apr 02 #Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
Apr 02 #Javascript
Node.js中package.json中库的版本号(~和^)
Apr 02 #Javascript
You might like
php Smarty模板生成html文档的方法
2010/04/12 PHP
PHP 字符串加密函数(在指定时间内加密还原字符串,超时无法还原)
2010/04/28 PHP
ThinkPHP框架分布式数据库连接方法详解
2017/03/14 PHP
如何制作浮动广告 JavaScript制作浮动广告代码
2012/12/30 Javascript
AngularJS删除路由中的#符号的方法
2016/09/20 Javascript
nodejs的HTML分析利器node-jquery用法浅析
2016/11/08 NodeJs
js 点击a标签 获取a的自定义属性方法
2016/11/21 Javascript
String字符串截取的四种方式总结
2016/11/28 Javascript
el表达式 写入bootstrap表格数据页面的实例代码
2017/01/11 Javascript
JavaScript函数节流的两种写法
2017/04/07 Javascript
分享十三个最佳JavaScript数据网格库
2017/04/07 Javascript
jQuery EasyUI 选项卡面板tabs的使用实例讲解
2017/12/25 jQuery
使用nodejs+express实现简单的文件上传功能
2017/12/27 NodeJs
jQuery设置下拉框显示与隐藏效果的方法分析
2019/09/15 jQuery
Node.js开发之套接字(socket)编程入门示例
2019/11/05 Javascript
jQuery操作元素追加内容示例
2020/01/10 jQuery
jquery实现的放大镜效果示例
2020/02/24 jQuery
微信小程序动态添加和删除组件的现实
2020/02/28 Javascript
JavaScript 中判断变量是否为数字的示例代码
2020/10/22 Javascript
[03:46]显微镜下的DOTA2第七期——满血与残血
2014/06/20 DOTA
python图像处理之反色实现方法
2015/05/30 Python
基于进程内通讯的python聊天室实现方法
2015/06/28 Python
python简单猜数游戏实例
2015/07/09 Python
python 顺时针打印矩阵的超简洁代码
2018/11/14 Python
Python中的集合介绍
2019/01/28 Python
python3处理word文档实例分析
2020/12/01 Python
利用python爬取有道词典的方法
2020/12/08 Python
CSS的background属性及CSS3的背景图片设置总结
2016/06/13 HTML / CSS
加拿大在线旅游公司:Flighthub
2019/03/11 全球购物
大专生自我鉴定范文
2013/10/01 职场文书
大学生求职工作的自我评价
2014/02/13 职场文书
2014年采购工作总结
2014/11/20 职场文书
求职自我推荐信
2015/03/24 职场文书
解除处分决定书
2015/06/25 职场文书
python垃圾回收机制原理分析
2022/04/13 Python
Nginx开源可视化配置工具NginxConfig使用教程
2022/06/21 Servers