博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
通用的验证模块
阅读量:6607 次
发布时间:2019-06-24

本文共 4041 字,大约阅读时间需要 13 分钟。

分享一个新鲜出炉的验证模块,用各种环境的规则验证,结合React或Vue做到无侵入式验证,做纯数据验证,不操作相关DOM与事件注册,规则配置方便,简单易用。

使用过很多的验证插件,总是没有一个特别让我满意,要么规则配置复杂,要么样式更改麻烦,这种大而全的框架在特定的环境下是很有用的,可以帮忙节省大量时间,可在一些定制性要求高的场景下,却总是不够灵活,依赖各种环境和框架,于是,还是来自己动手封装一个简单的工具吧。

下面是这个工具的介绍和使用:

依赖ES6的 Promise,如果需要低版本浏览器支持,请使用 dist/lite-validator-es5.js

安装

npm install lite-validator --save复制代码

ES6 引用

import { validForm, validValue, validField } from 'lite-validator'复制代码

AMD 引用

var liteValidator = require('lite-validator');validForm = liteValidator.validForm;validValue = liteValidator.validValue;validField = liteValidator.validField;复制代码

浏览器引用

复制代码

API

极简的API,记住下面这三个API,走遍天下,验证我不怕?

  • validForm 验证整个 表单
  • validField 验证单个 字段
  • validValue 验证单个 数值

validValue

做纯数据的验证,返回 truefalse

validValue(value, ruleName, pms)validValue.ruleName(value, pms)

value 数值

ruleName 规则名称
pms 规则的参数,可以是多个,具体参数见下面的默认规则

validValue.required(' ')//falsevalidValue.qq('123')//falsevalidValue.phone('1761231221')//falsevalidValue.email('1761231221')//falsevalidValue.Length('1761231221', '~5')//false 由于length与函数的length冲突,这里将首字母大写,暂时只有这一个规则是大写validValue.range('3', '1~5')//true 默认转换为数值类型···复制代码

validField

用于表单中 单个字段 的验证,可以 组合 多种规则,异步验证 某个字段

validField (formEl, field, rules)

formEl 表单的DOM对象

field 可以是字段的 name 名称,也可以是字段的DOM对象
rules 规则数组

let i = 0;validField(formEl, 'name', [    ['required'],    [(el)=>{     window.timmerx = setInterval(()=>console.log(++i), 1000);     return new Promise((r,j)=>{      setTimeout(()=>{r(el.value); clearInterval(window.timmerx)}, 3000);     })}    ]  ]).then(res =>{  console.log('验证通过:'+res)}).catch(err =>{  console.log(err.msg || '')})复制代码

validForm

用于验证整个表单,默认是遇到验证失败时就停止验证

validForm(formEl, fieldsRules, validAll)

formEl 表单DOM对象

fieldRules 所有字段的验证配置
validAll 是否一次性验证所有字段

//逐个验证,遇到错误时,停止验证,常用于移动端表单验证validForm(oFormBox, {  'uName':[['required'],['length:~10','字符长度过长,请小于10个字符']],  'uAge': [['required'],['range:25~40','请输入25至40周岁']],  'uEmail': [['required'],['email']],  'uBirthday': [['required'],['date']],  'invalicode': [['required']],  'uPwd': [['required'],['password']],  'rePwd': [['required'],['match:uPwd','与密码输入不一致']],  'address': [['required'],['chinese']],  'city': [['required'],['checked:1~','至少选择1项']],}).then(res=>console.log(res)).catch(err=>{    if(err instanceof Error) throw err;    console.log(err.msg);})// 一次性验证所有字段,常用于PC端表单验证validForm(oFormBox, {  'uName':[['required'],['length:~10','字符长度过长,请小于10个字符']],  'uAge': [['required'],['range:25~40','请输入25至40周岁']],  'uEmail': [['required'],['email']],  'uBirthday': [['required'],['date']],  'invalicode': [['required']],  'uPwd': [['required'],['password']],  'rePwd': [['required'],['match:uPwd','与密码输入不一致']],  'address': [['required'],['chinese']],  'city': [['required'],['checked:1~','至少选择1项']],}, true).then(res=>{  console.log(res)}).catch(err=>{  console.log(err)})复制代码

验证成功

返回成功字段的验证信息
如果是遇到错误就停止,则返回一个对象 {el:inputObj, field:fieldName}
如果是一次性验证所有字段,则返回这个对象组成的数组

验证失败

如果在验证过程中失败,出现异常,则返回异常对象
如果是验证规则失败,则返回,失败的字段信息对象 {el:inputObj, msg:errmsg, field:fieldName}
如果是一次性难所有字段,则返回这个对象组成的数组

内置规则

常用正则

必填项

  • required 字段必填

整数

  • integer 整数
  • integer(+) 正整数
  • integer(+0) 正整数和零
  • integer(-) 负整数
  • integer(-0) 负整数和零

长度

  • length(n) 请填写 n 个字符
  • length(n~) 请至少填写 n 个字符
  • length(~n) 请最多填写 n 个字符
  • length(n1~n2) 请填写 n1 到 n2 个字符

选择数量 Checkbox

  • checked 必选
  • checked(n) 必选 n 项
  • checked(n~) 至少选择 n 项
  • checked(~n) 最多选择 n 项
  • checked(n1~n2) 选择 n1 到 n2 项

选择范围

  • range(n~) 请填写不小于 n 的数
  • range(~n) 请填写不大于 n 的数
  • range(n1~n2) 请填写 n1 到 n2 的数

过滤

  • filter 过滤 <>"'\ 和字符实体编码的字符

过滤隐藏字段和禁用字段

在验证表单时,会先过滤出配置的字段中,不是隐藏或禁用的字段,禁用的字段主要判断,主要判断该表单控件是否有属性 disabled 或 class disabled

自定义规则与提示

在表单验证中,可以配置组合多个验证规则,可以配置验证失败的错误提示,如果不设置,也可以使用默认规则中的配置的提示信息, 如果默认配置中没有,则取该字段的 placeholder

'uName':[      ['required', '请输入姓名1'],      ['length:2~5', '字符数2到5个'],      ['integer:+'],      ['range:1~3', '大于1小于等于3'],      ['checked:1~', '至少选择1个'],      ['match:pwd', '和pwd这个字段值必须相同'],      [/^[Α-¥]+$/, '请输入中文字符'],      [()=>{
return Promise.resolve(1)}, '名称已经存在了']复制代码

提示的优先级

自定义的提示 > 默认规则的配置 > placeholder

CodePen示例

See the Pen by LT () on .

源码

欢迎来给我提ISSUES

转载于:https://juejin.im/post/5856a32c61ff4b00685c4e98

你可能感兴趣的文章
Linux Shell之三 高级变量及字符串
查看>>
Memcached的备份负载
查看>>
快速预览Office 15服务端:Exchange 2013
查看>>
shell脚本备份数据库
查看>>
echo(),print(),print_r()三者的区别
查看>>
Mac上面Docker构建镜像时超时
查看>>
hdu1406
查看>>
samba服务搭建
查看>>
Problem(二):count++ 与 ++count
查看>>
通俗易懂grub
查看>>
我的友情链接
查看>>
SICP 1.14 1.15
查看>>
CS224n笔记8 RNN和语言模型
查看>>
学习 SQL 语句 - Select(9): 其他
查看>>
给动态数组添加一个元素
查看>>
【Java每日一题】20170317
查看>>
php中curl_multi函数集的用法
查看>>
linux设置目录权限命令
查看>>
新人培训总结
查看>>
Myeclipse常用快捷键
查看>>