Element表单验证(1)
Element表单验证(1)
首先要掌握Element官方那几个表单验证的例子,然后才看下面的教程。
Element主要使用了async-validator这个库作为表单验证
async-validator主要分成三部分
- Validate
- Options
- Rules
其中,对于我们使用Element的来说,Rules最重要,也是这部分内容较多的。
async-validator各部分
async-validator基本使用
import Validator from 'async-validator'
// 规则的描述
const rules = {
name: { type: 'string', required: true }
}
// 根据规则生成验证器
const validator = new Validator(rules)
// 要验证的数据源
const source = {
name: 'LanTuoXie'
}
// 验证后的回调函数
function callback (errors, fileds) {
if (errors) {
// 验证不通过,errors是一个数组,记录那些不通过的错误信息
// fileds是所有数据源的字段名,也即上面的source的'name'
// 验证是根据字段名来的,rules.name 对应 source.name。 字段名要一样才会验证
}
// 下面是验证通过的逻辑
}
// 验证数据源是否符合规则
validator.validate(source, callback)
Validate
就是上面例子中的validator.validate,是一个函数
function(source, [options], callback)
source和callback对应上面的例子。
Options
Options有两个值
first: 一个布尔值,如果出现字段不通过,终止验证后面的字段firstFields: 布尔值或者字符串,如果验证一个字段时,一个规则不通过,终止验证下个规则(一个字段,多个规则的情况)
firstFields是针对单个字段多规则的情况下使用,而first是针对所有字段
Rules
最重要的还是Rules。定义rule可以有三种形式,但是rules字段名一定要和数据源source的字段名一致。
- 函数的方式:
{ name(rule, value, callback, source, options) {} } - 对象的方式:
{ name: { type: 'string', required: true } } - 数组的方式:
{ name: [{ type: 'string' }, { required: true }] }
上面可以看到,字段名name可以有3种方式定义规则,在使用Element的时候还是推荐对象和数组的方式,这个两个比较简单,函数看情况使用。
除了type和required还有哪些用法可以用以及有什么用?
Rules的默认规则
type: 要被验证的数据的类型如url和number等required: 是否必填pattern:使用正则来验证min: 数据的长度的最小值 (数据类型必须是string或array)max: 数据的长度的最大值 (数据类型必须是string或array)len: 数据的长度必须等于这个值 (数据类型必须是string或array)enum: 数据的值必须等于这个枚举数组某个元素{ enum: [1, 2, 3] }transform: 一个钩子函数,在开始验证之前可以对数据先处理后验证,如吧number转为string后再验证message: 报错的提示信息可以是字符串也可以是jsx标签<span>Name is required</span>validator: 自定义验证函数以及报错信息validator(rule, value, callback)- 还有一个Deep Rules是处理
object或者array类型的,使用了fields或defaultField fields:Deep Rules的时候使用,定义下一层的字段名以及规则defaultField: Deep Rules的时候使用,所有下一层的字段都会采用该规则,可以被fields替换
默认的Type
string:必须是String类型,规则不设置type默认是这个number:必须是Number类型,如果后台返回的数据是字符串,可以用transform转为Number类型,字符串类型的数字('12')不会通过,要注意boolean: 必须是Boolean类型method: 必须是Functionregexp:必须是正则RegExpinteger:是Number类型的正整数float: 是Number类型的浮点数array: 是Array.isArray通过的数组object: Array.isArray不通过的Object类型enum: 要先定义enum,然后值必须是enum某个值date: 必须是Date对象的实例url: String类型且符合链接格式hexemail: String类型,且符合邮箱格式
Deep Rules使用demo
cosnt urls = ['http://www.baidu.com', 'http://www.baidu.com']
// 一个urls的数组,
const rules = {
urls: {
type: 'array',
required: true,
defaultField: { type: 'url' }
}
}
const ids = {
name: 'LanTuoXie',
age: 12,
spc: '帅'
}
const rules = {
ids: {
type: 'object',
required: true,
fields: {
name: { type: 'string', required: true },
age: { type: 'number', required: true, tranform: Number },
spc: { type: 'string', required: true }
}
}
}
自定义验证validator
validator(rule, value, callback)
rule: 记录了验证字段的字段名以及规则的信息value: 要验证的值callback: 如果callback()代表验证通过,如果callback(new Error('错误要提示的信息'))代表验证不通过
// 验证是[min, max]范围内的正整数
const betweenInt = (min, max) => (rule, v, cb) => {
const isBetween = v >= min && v <= max
const isInt = /^[0-9]+$/.test(v)
if (isBetween && isInt) return cb()
return cb(new Error(`要求是在${min}到${max}的正整数 [${min}, ${max}]`))
}
const rules = {
num: { validator: betweenInt(1, 5), required: true }
}
Element表单验证(1)的更多相关文章
- Element表单验证(2)
Element表单验证(2) 上篇讲的是async-validator的基本要素,那么,如何使用到Element中以及怎样优雅地使用,就在本篇. 上篇讲到async-validator由3大部分组成 ...
- async-validator:Element表单验证
转载文章:Element表单验证(2) Element表单验证(2) 上篇讲的是async-validator的基本要素,那么,如何使用到Element中以及怎样优雅地使用,就在本篇. 上篇讲到a ...
- vue element 表单验证不通过,滚动到固对应位置
我们在使用elementIUI实现表单验证,内容比较多的时候,提示内容会被遮挡,这时候用户不清楚什么情况,还会连续点击提交按钮.这个时候需求来啦:我们需要在表单验证不通过的时候,页面滚动到对应的位置. ...
- vue+element 表单验证
效果图 <template> <div class="formValidator"> <div v-for="(item,index) in ...
- Element表单验证规则
一.简单的逻辑验证使用方法: 方法步骤: 1.在html中给el-form增加 :rules="rules" 2.html中在el-form-item 中增加属性 prop=&qu ...
- Element 表单验证,不清空数据,仅仅取消表单字段校验
重置表单 this.$refs['ageForm'].resetFields() // 表单重置 仅清空校验 this.$refs['ageForm'].clearValidate() // 清除验证
- 解决“element表单验证输入的数字检测出来是string”的问题
form表单: 校验规则: 注意:一.数字类型的验证需要在 v-model 处加上 .number 的修饰符,这是 Vue 自身提供的用于将绑定值转化为 number 类型的修饰符.二.校验中是否添加 ...
- element表单验证
rules: { name:[{ required: true, message: '请输入用户名', trigger: 'blur' },{ min: 2, max: 5, message: '长度 ...
- JS判断字符串长度,结合element el-input el-form 表单验证(英文占1个字符,中文汉字占2个字符)
首先看看判断字符串长度的几种方法(英文占1个字符,中文汉字占2个字符) 方法一: function strlen(str) { var len = 0; for (var i = 0; i < ...
随机推荐
- 性能测试工具Jmeter10-Jmeter集合点与关联
集合点 操作步骤: 注意:集合点要放在需要集合的元件前面 关联 正则表达式提取器 配置说明 引用名称:下一个请求要引用的参数名称,如token,则可用${token}引用它 正则表达式: () 括起来 ...
- [转]jQuery调用ASPX返回json
本文转自:http://www.cnblogs.com/fire-phoenix/archive/2009/11/13/1614146.html 本文介绍如何在ASP.NET(ASP.NET/AJAX ...
- w3schools juerymobile
http://www.w3schools.com/jquerymobile/jquerymobile_examples.asp <!DOCTYPE html> <html> & ...
- nginx 访问路径配置
比如: http://127.0.0.1/ 对应的物理路径 c:/a/b/c 比如:http://127.0.0.1/eec 访问的地址对应的物理路径: d:/a/b/c #user nobody; ...
- nodejs --- crypto实现加密(转)
crypto实现加密 本文转自:http://www.liaoxuefeng.com/wiki/001434446689867b27157e896e74d51a89c25cc8b43bdb3000/0 ...
- 硬盘和显卡的访问与控制(一)——《x86汇编语言:从实模式到保护模式》读书笔记01
本文是<x86汇编语言:从实模式到保护模式>(电子工业出版社)的读书实验笔记. 这篇文章我们先不分析代码,而是说一下在Bochs环境下如何看到实验结果. 需要的源码文件 第一个文件是加载程 ...
- join() 和 sleep() 区别
来源于<Java多线程编程核心技术> 一.join() 作用 在很多情况,主线程创建并启动子线程,如果子线程中需要进行大量的耗时计算,主线程往往早于子线程结束.这时,如果主线程想等待子线程 ...
- java web api接口调用
Web Services 被W3C进行了标准化定义. Web Services 发布到网上,可以公布到某个全局注册表,自动提供服务URL,服务描述.接口调用要求.参数说明以及返回值说明.比如中国气象局 ...
- 登录mysql数据库出现 : ERROR 1045 (28000): Access denied for user 'ODBC'@'localhost' (using password: NO) ER或者忘记密码
1. 在安装mysql的文件目录中找到配置文件my.ini ,然后右击用记事本打开 2. 打开后,搜索mysqld关键字 找到后,在mysqld下面添加skip-grant-tabl ...
- Struts2_Path
路径问题说明: struts2中的路径问题是根据action的路径而不是jsp路径来确定,所以尽量不要使用相对路径.index.jsp虽然可以用rederect方式解决,但redirect方式并非必要 ...