Skip to content

💯 简单灵活的表单验证插件,支持微信小程序、支付宝小程序、浏览器以及Nodejs端使用

License

Notifications You must be signed in to change notification settings

yuioqp/we-validator

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

31 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

we-validator

简单灵活的表单验证插件

NPM

Build Status Language License

支持微信小程序、支付宝小程序、浏览器以及Nodejs端使用。

特点

安装

非 npm 安装方式,直接引入 lib 目录下的 we-validator.js 到项目即可

npm install we-validator --save

使用

下面是微信小程序的用法,支付宝小程序类似

<form bindsubmit="onSubmitForm">
    <input type="text" name="username" placeholder="用户名" />
    <input type="number" name="phoneno" placeholder="手机号" />
    <input type="text" name="str" placeholder="长度为3的字符串" />

    <button type="default" formType="submit">提交</button>
</form>
const WeValidator = require('we-validator')

Page({
    onReady(){
        this.initValidator()
    },
    onSubmitForm(e){
        let { value } = e.detail

        if(!this.validatorInstance.checkData(value)) return

        // 开始提交表单
        // wx.request
    },
    initValidator(){
        // 实例化
        this.validatorInstance = new WeValidator({
            rules: {
                username: {
                    required: true
                },
                phoneno: {
                    required: true,
                    mobile: true
                },
                str: {
                    required: true,
                    stringLength: 3
                },
            },
            messages: {
                username: {
                    required: '请输入用户名'
                },
                phoneno: {
                    required: '请输入手机号',
                    mobile: '手机号格式不正确'
                },
                str: {
                    required: '请输入字符串',
                    stringLength: '字符串长度不对'
                },
            },
        })
    },
})

您可参考当前项目下对应示例

API

Static API

new WeValidator(options) ⇒ object

实例化

返回: object - validatorInstance

参数 类型 默认值 描述
options object
[options.rules] object 验证字段的规则
[options.messages] object 验证字段错误的提示信息
[options.onMessages] function 错误提示显示方式,默认会自动检测环境。小程序默认使用showToast,普通web浏览器默认使用alert,Nodejs端不做处理建议自己配置,详情

示例

const WeValidator = require('we-validator')

new WeValidator({
    rules: {
        username: {
            required: true
        },
        phoneno: {
            required: true,
            mobile: true
        }
    },
    messages: {
        username: {
            required: '请输入用户名'
        },
        phoneno: {
            required: '请输入手机号',
            mobile: '手机号格式不正确'
        }
    }
})

.checkData(data, onMessage) ⇒ boolean

校验数据

返回: boolean

参数 类型 默认值 描述
data object 需要校验的表单数据
onMessage function 自定义错误消息提示,详情

.isValid(data) ⇒ boolean

校验数据是否有效,无提示

返回: boolean

参数 类型 默认值 描述
data object 需要校验的表单数据

.addRules(options)

动态添加校验

options 参数和实例化 new WeValidator(options) 一样,详情

const WeValidator = require('we-validator')

const validatorInstance = new WeValidator({
    rules: {
        username: {
            required: true
        }
    },
    messages: {
        username: {
            required: '请输入用户名'
        }
    }
})

// 动态添加校验
validatorInstance.addRules({
    rules: {
        phoneno: {
            required: true,
            mobile: true
        }
    },
    messages: {
        phoneno: {
            required: '请输入手机号',
            mobile: '手机号格式不正确'
        }
    }
})

.removeRules(rules)

动态移除校验

参数 类型 默认值 描述
rules Array 需要移除校验的表单字段
validatorInstance.removeRules(['username'])

WeValidator.addRule(ruleName, callback)

静态方法:添加自定义规则

参数 类型 默认值 描述
ruleName string 规则名称
callback function 规则校验函数,需要返回一个 boolean,参考下面
const WeValidator = require('we-validator')

// 添加自定义规则
WeValidator.addRule('theRuleName', function(value, param){
    return /\d/.test(value)
})

// 使用方式一,实例化
new WeValidator({
    rules: {
        field1: {
            theRuleName: true
        }
    },
    message: {
        field1: {
            theRuleName: '提示信息'
        }
    }
})

// 使用方式二,调用函数
WeValidator.theRuleName('str')

WeValidator.$value(ruleName)

静态方法:值相同校验,例如二次密码校验

参数 类型 默认值 描述
ruleName string 要比较的字段名称
const WeValidator = require('we-validator')

// 实例化
new WeValidator({
    rules: {
        pwd1: {
            required: true
        },
        pwd2: {
            required: true,
            equal: WeValidator.$value('pwd1')
        }
    },
    messages: {
        pwd1: {
            required: '请输入密码'
        },
        pwd2: {
            required: '请输入确认密码',
            equal: '两次密码不一致'
        }
    }
})

支持的正则类型

具体正则内容可查看源码

  • bankCard - 银行卡
  • mobile - 手机号
  • mobileWithSpace - 手机号(带空格131 2233 4455
  • idCard - 身份证
  • chinese - 中文
  • chinese2to8 - 中文(2-8位)
  • intOrFloat - 整数或小数
  • int - 整数
  • noZeroStart - 非零开头的数字
  • specialStr - 含有^%&',;=?$"等特殊字符
  • email - 邮箱
  • httpUrl - InternetURL地址
  • tel - 电话号码,正确格式为:"XXX-XXXXXXX"、"XXXX-XXXXXXXX"、"XXX-XXXXXXX"、"XXX-XXXXXXXX"、"XXXXXXX"和"XXXXXXXX"
  • money - 货币
  • month - 一年的12月,正确格式为:"01"~"09"和"1"~"12"
  • day - 一个月的31天,正确格式为;"01"~"09"和"1"~"31"
  • html - 匹配html标签
  • spaceEnter - 匹配空行
  • qq - qq号码
  • zip - 邮编
  • doubleByte - 匹配双字节字符(包括汉字在内)

规则

除了支持以上所有正则规则,以下特殊规则也支持,可动态传参(上面正则和下面特殊规则的使用方式一样)

  • required: true,必填
  • regex: RegExp,正则通用校验
  • equal: WeValidator.$value(compareName),字段值是否相同,例如二次密码校验,参考
  • intGreater: n,大于n的数字
  • intLength: n,只能输入n位的数字
  • intLessLength: n,至少n位数字
  • intLengthRange: [n, m],n到m位数字
  • decimalLength: n,只能输入有n位小数的正实数
  • decimalLengthRange: [n, m],只能输入有n~m位小数的正实数
  • stringLength: n,长度为n的字符串
  • stringLetter: aorA,由26个英文字母组成的字符串,大写或小写类型,A表示大写,a表示小写,其它表示不限制大小写
  • stringLetterDefault: true,由数字、26个英文字母或者下划线组成的字符串

其它

动态传入参数的使用

const WeValidator = require('we-validator')

// 使用方式一,实例化(推荐)
new WeValidator({
    rules: {
        field1: {
            intGreater: 6 // 大于6的数字
        },
        field2: {
            intLengthRange: [2, 5] // 2-5位数字
        }
    },
    messages: {
        field1: {
            intGreater: '请输入大于6的数字'
        },
        field2: {
            intLengthRange: '请输入2-5位数字'
        }
    }
})

// 使用方式二,调用函数(支持默认提供的所有正则规则类型的函数调用)
let b1 = WeValidator.intGreater('str', 6) // 大于6的数字
let b2 = WeValidator.intLengthRange('str', 2, 5) // 2-5位数字

自定义错误消息提示

可以全局配置一个,也可以单独配置。优先级是:验证的时候onMessage > 实例化参数onMessage > 全局onMessage > 默认检测

const WeValidator = require('we-validator')

// 1、全局配置
WeValidator.onMessage = function(data){
    /*
    data 参数
    {
        msg, // 提示文字
        name, // 表单控件的 name
        value, // 表单控件的值
        param // rules 验证字段传递的参数 []
    }
    */
}

// 2、实例化配置
new WeValidator({
    rules: {},
    message: {},
    onMessage: function(data){
        alert(data.msg)
    }
})

// 3、验证的时候配置 onMessage(nodejs端校验可以使用此方式)
function onMessage(data){
  alert(data.msg)
}
if(!obj.checkData(formData, onMessage)){
     return
}

协议

license

About

💯 简单灵活的表单验证插件,支持微信小程序、支付宝小程序、浏览器以及Nodejs端使用

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • JavaScript 92.3%
  • HTML 4.7%
  • Vue 3.0%