element-ui-verify使用
element-ui-verify是对ElementUI原本的校验封装之后的插件,并不会影响使用ElementUI的原生校验。
使用环境为vue+element-ui+webpack模块环境,首先使用淘宝镜像安装cnpm install -s element-ui-verify,安装之后在main.js中引入并使用
import elementUIVerify from 'element-ui-verify' // 注意使用之前必须要先use elementUI
Vue.use(elementUIVerify)
main.js使用之后就可以直接在el-form-item标签上使用校验规则了,例如下面代码表示内容大于0的校验:
<el-form-item label="年龄" prop="age" verify int :gt="0">
<el-input v-model.number="model.age"></el-input>
</el-form-item>
默认支持的校验规则
| length | 校验文本长度 |
| minLength | 校验文本最短长度 |
| gt | 校验数字要大于某数 |
| gte | 校验数字要大于等于某数 |
| lt | 校验数字要小于某数 |
| lte | 校验数字要小于等于某数 |
| maxDecimalLength | 校验数字最大小数位 |
| number | 校验是否为数字 |
| int | 校验是否为整数 |
| phone | 校验是否为手机号(随着号段的增加,未来可能需要更新) |
| 校验是否为电子邮件地址 | |
| verifyCode | 校验是否为6位数字验证码 |
使用这个插件,verify是必须的,如果想使用原生的elementUI校验规则就不需要写verify。
其他关键字说名
canBeEmpty:可以为空,当不为空时又需要校验;
space:使用该关键字时空格也参加校验;
emptyMessage:空检测错误提示;
errorMessage:自定义校验不通过提示;
<el-form-item prop="numberProp" verify number error-message="请输入正确的数字"></el-form-item>
alias:复用错误提示,插件默认值:"该输入项",使用这个关键字可以{alias}不能为空
例如空检测错误提示模板为:
{empty: '{alias}不能为空'}
表单内容为:
<el-form-item prop="unknown" verify></el-form-item>
<el-form-item alias="姓名" prop="name" verify></el-form-item>
<el-form-item label="地址" prop="address" verify></el-form-item>
- 当
unknown输入框为空时,会提示"该输入项不能为空"(alias值默认为"该输入项") - 当
姓名输入框为空时,会提示"姓名不能为空"(显式设置了alias值时,提示内容自然会以该值去替换模板) - 当
地址输入框为空时,会提示"地址不能为空"(大部分el-form-item都需要设置一个label项,而label项往往就代表该输入项的alias,因此插件会取该值直接作为alias)
watch:监听其他变量触发自身校验,例如修改密码
<template>
<el-form :model="model">
<el-form-item label="密码" prop="pass1" verify>
<el-input v-model="model.pass1"></el-input>
</el-form-item>
<el-form-item label="确认密码" prop="pass2" :verify="verifyPassword" :watch="model.pass1">
<el-input v-model="model.pass2"></el-input>
</el-form-item>
</el-form>
</template>
<script>
export default{
data () {
return {
model: {
pass1: '',
pass2: ''
}
}
},
methods: {
verifyPassword (rule, val, callback) {
if (val !== this.model.pass1) callback(Error('两次输入密码不一致!'))
else callback()
}
}
}
</script>
自定义校验规则
开发中如果自带的校验规则满足不了需求,我们通常将在全局自定义校验规则,首先在src目录下新建文件夹,我的文件夹叫verifyRule,文件夹中新建index.js文件,通过模块化导出校验规则。
export default [{
rule: {
name: 'blacklist',
},
ruleMethod: () => ({
validator(rule, val, callback) {
let windowvue = window.vue;
windowvue.$http.post('校验接口',{searchKey: val}).then(function(result){
if(result){
callback(new Error('错误提示信息));
}else{
callback();
}
});
}
})
}
];
然后在main.js里遍历添加校验规则
import ElementUIVerify from 'element-ui-verify'
Vue.use(ElementUIVerify)
// node中如果包下无法通过package.json找到main会自动读取包下的index.js文件
import verifyrules from '@/verifyRule' verifyrules.forEach(item => {
ElementUIVerify.addRule(item.rule, item.ruleMethod);
})
添加之后就可以在项目中通过‘blacklist‘使用自定义的校验规则。
<el-form-item label="身份证号" prop="customerCardNO" verify blacklist ></el-form-item>
element-ui-verify使用的更多相关文章
- 使用element ui 日期选择器获取值后的格式问题
一般情况下,我们需要给后台的时间格式是: "yyyy-MM-dd" 但是使用Element ui日期选择器获取的值是这样的: Fri Sep :: GMT+ (中国标准时间) 在官 ...
- element ui 1.4 升级到 2.0.11
公司的框架 选取的是 花裤衩大神开源的 基于 element ui + Vue 的后台管理项目, 项目源码就不公开了,记录 分享下 步骤 1. 卸载 element ui 1.4的依赖包 2. 卸载完 ...
- [坑况]饿了么你是这样的前端——vue+element ui 【this dependency was not found:'element-ui/lib/theme-chalk/index.css'】
element ui 坑况:今日pull代码,潇洒npm run dev ,被告知:this dependency was not found:'element-ui/lib/theme-chalk/ ...
- Vue + Element UI项目初始化
1.安装相关组件 1.1安装Node 检查本地是否安装node node -v 如果没有安装,从Node官网下载 1.2安装npm npm -v 如果没有安装:使用该指令安装: npm install ...
- Element UI——本地引入iconfont不显示
前言 前面因为本地引入Element UI导致了iconfont不显示,所以只好再去Element UI官网去扒下iconfot 步骤 进入官网 组件 | Element UI F12进入控制台,找到 ...
- Html | Vue | Element UI——引入使用
前言 做个项目,需要一个效果刚好Element UI有,就想配合Vue和Element UI,放在tp5.1下使用,但是引入在线的地址各种报错,本地引入就完美的解决了问题! 代码 __STATIC_J ...
- 分享一个自搭的框架,使用Spring boot+Vue+Element UI
废弃,新的:https://www.cnblogs.com/hackyo/p/10453243.html 特点:前后端分离,可遵循restful 框架:后端使用Spring boot,整合了aop.a ...
- 上传图片组件封装 element ui
// element ui 文档地址: http://element.eleme.io/#/zh-CN <template> <div> <div class=" ...
- vue项目使用element ui的Checkbox
最近使用到element ui的下拉多选框Checkbox Checkbox用法可参考与于 http://element.eleme.io/#/zh-CN/component/checkbox Che ...
- vue的$nextTick使用总结,this.$refs为undefined的解决办法,element Ui的树形控件setCheckedKeys方法无法使用
其实这3个讲的是一个问题,先说下问题,我在watch里设置一个监听,当弹窗打开时,自动添加树形的默认选中项, 但奇怪的是this.$refs为undefined,自然setCheckedKeys无法使 ...
随机推荐
- hadoop day 6
1.为hive配置mysql数据库 conf/hive-site.xml <property> <name>javax.jdo.option.ConnectionURL< ...
- C#中的Cookie
cookie属性: name字段为一个cookie的名称. value字段为一个cookie的值. domain字段为可以访问此cookie的域名. path字段为可以访问此cookie的页面路径. ...
- 2PC(Two Phase Commitment Protocol)原理
读TiDB原理部分,知道其分布式事务是参考的Google percolator.而percolator是一种2PC的优化. 分布式事务解决的是什么问题呢? 假设一个场景,一个电商网站,用户在购买商品时 ...
- 在typeScript+vue项目中使用ref
因为vue项目是无法直接操作dom的,但是有时候开发需求迫使我们去操作dom. 两个办法,一个是很low的再引入jq,然后通过jq来操作,但是这样就失去了我们使用vue的意义, 可惜的是我曾经这样干过 ...
- HTML5网页制作(3)
今天,就开始嵌入图片以及创建图片分区的学习吧! 这两张图片其实是我用HTML5写的(纯粹当做笔记来记了),以上就是今天要学的一些内容 下面是我今天敲的代码: [冒泡]林北的爸爸 2019/4/29 ...
- 请求转发和URL重定向的原理和区别
一.请求转发和重定向是在java后台servlet中,由一个servlet跳转到另一个servlet/jsp要使用的技术 使用方法 请求转发 req.getResquestDispatcher(se ...
- servlet的生命周期和servlet的继承关系
一.servlet的生命周期 一个servlet类的对象 加载——>实例化——>初始化——>服务——>销毁 第一次访问某个servlet的时候 首先调用其 构造函数 pub ...
- 关于xampp mysql字符编码与编译器编码不匹配问题
今天,在php中对数据库字符字段进行查询的时候,语法之类的完全正确,但是就是查询不到结果,而在命令行中,同样的语句却能获得预期的功效.经多方面的了解之后才发现是字符编码不匹配的原因.在这里,把我的解决 ...
- 让你真正了解Java(纯干货)
“你学习一门技术的最佳时机是三年前,其次是现在.”这句话对于哪一种行业都很适用,如果你已经学习过Java,那么恭喜你你很有先见之明,如果你并不了解Java,这篇文章带你快速掌握Java的几个核心知识点 ...
- Redis事务和实现秒杀功能的实现
今天带着学生学习了Redis的事务功能,Redis的事务与传统的关系型数据库(如MySQL)有所不同,Redis的事务不能回滚. Redis中使用multi.exec.discard.watch.un ...