您的位置:首页技术文章
文章详情页

微信小程序表单验证怎么弄?

浏览:42日期:2022-07-15 16:31:26

微信小程序表单验证怎么弄?微信小程序正式上线,相信很多人都已经开始使用了。简单的表单验证,也不算是验证了,只是封装了一下提示消息,免得自己去手动写if else(大家都懂吧),用起来还行吧,自己动手丰衣足食。

微信小程序表单验证怎么弄?

插件地址:https://github.com/skyvow/m-mall/blob/master/helpers/WxValidate.js

代码示例:

/×*

* 创建验证字段的工厂函数

*

* @param {Object} rules 验证字段的规则

* @param {Object} messages 验证字段的提示信息

*

*/

class WxValidate {

constructor(rules = {}, messages = {}) {

Object.assign(this, {

rules,

messages,

})

this.__init()

}

/×*

* __init

*/

__init() {

this.__initMethods()

this.__initDefaults()

this.__initErrorList()

}

/×*

* 初始化错误信息

*/

__initErrorList() {

this.errorList = []

}

/×*

* 初始化默认提示信息

*/

__initDefaults() {

this.defaults = {

messages: {

required: '这是必填字段。',

email: '请输入有效的电子邮件地址。',

tel: '请输入11位的手机号码。',

url: '请输入有效的网址。',

date: '请输入有效的日期。',

dateISO: '请输入有效的日期(ISO),例如:2009-06-23,1998/01/22。',

number: '请输入有效的数字。',

digits: '只能输入数字。',

idcard: '请输入18位的有效身份证。',

equalTo: this.formatTpl('输入值必须和 {0} 相同。'),

contains: this.formatTpl('输入值必须包含 {0}。'),

minlength: this.formatTpl('最少要输入 {0} 个字符。'),

maxlength: this.formatTpl('最多可以输入 {0} 个字符。'),

rangelength: this.formatTpl('请输入长度在 {0} 到 {1} 之间的字符。'),

min: this.formatTpl('请输入不小于 {0} 的数值。'),

max: this.formatTpl('请输入不大于 {0} 的数值。'),

range: this.formatTpl('请输入范围在 {0} 到 {1} 之间的数值。'),

}

}

}

/×*

* 初始化默认验证方法

*/

__initMethods() {

const that = this

that.methods = {

/×*

* 验证必填元素

*/

required(value, param) {

if (!that.depend(param)) {

return 'dependency-mismatch'

}

return value.length > 0

},

/×*

* 验证电子邮箱格式

*/

email(value) {

return that.optional(value) || /^[a-zA-Z0-9.!#$%&'*+/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/.test(value)

},

/×*

* 验证手机格式

*/

tel(value) {

return that.optional(value) || /^1[34578]d{9}$/.test(value)

},

/×*

* 验证URL格式

*/

url(value) {

return that.optional(value) || /^(?:(?:(?:https?|ftp):)?//)(?:S+(?::S*)?@)?(?:(?!(?:10|127)(?:.d{1,3}){3})(?!(?:169.254|192.168)(?:.d{1,3}){2})(?!172.(?:1[6-9]|2d|3[0-1])(?:.d{1,3}){2})(?:[1-9]d?|1dd|2[01]d|22[0-3])(?:.(?:1?d{1,2}|2[0-4]d|25[0-5])){2}(?:.(?:[1-9]d?|1dd|2[0-4]d|25[0-4]))|(?:(?:[a-zu00a1-uffff0-9]-*)*[a-zu00a1-uffff0-9]+)(?:.(?:[a-zu00a1-uffff0-9]-*)*[a-zu00a1-uffff0-9]+)*(?:.(?:[a-zu00a1-uffff]{2,})).?)(?::d{2,5})?(?:[/?#]S*)?$/i.test(value)

},

/×*

* 验证日期格式

*/

date(value) {

return that.optional(value) || !/Invalid|NaN/.test(new Date(value).toString())

},

/×*

* 验证ISO类型的日期格式

*/

dateISO(value) {

return that.optional(value) || /^d{4}[/-](0?[1-9]|1[012])[/-](0?[1-9]|[12][0-9]|3[01])$/.test(value)

},

/×*

* 验证十进制数字

*/

number(value) {

return that.optional(value) || /^(?:-?d+|-?d{1,3}(?:,d{3})+)?(?:.d+)?$/.test(value)

},

/×*

* 验证整数

*/

digits(value) {

return that.optional(value) || /^d+$/.test(value)

},

/×*

* 验证身份证号码

*/

idcard(value) {

return that.optional(value) || /^[1-9]d{5}[1-9]d{3}((0d)|(1[0-2]))(([0|1|2]d)|3[0-1])d{3}([0-9]|X)$/.test(value)

},

/×*

* 验证两个输入框的内容是否相同

*/

equalTo(value, param) {

return that.optional(value) || value === that.scope.detail.value[param]

},

/×*

* 验证是否包含某个值

*/

contains(value, param) {

return that.optional(value) || value.indexOf(param) >= 0

},

/×*

* 验证最小长度

*/

minlength(value, param) {

return that.optional(value) || value.length >= param

},

/×*

* 验证比较大长度

*/

maxlength(value, param) {

return that.optional(value) || value.length <= param

},

/×*

* 验证一个长度范围[min, max]

*/

rangelength(value, param) {

return that.optional(value) || (value.length >= param[0] && value.length <= param[1])

},

/×*

* 验证最小值

*/

min(value, param) {

return that.optional(value) || value >= param

},

/×*

* 验证比较大值

*/

max(value, param) {

return that.optional(value) || value <= param

},

/×*

* 验证一个值范围[min, max]

*/

range(value, param) {

return that.optional(value) || (value >= param[0] && value <= param[1])

},

}

}

/×*

* 添加自定义验证方法

* @param {String} name 方法名

* @param {Function} method 函数体,接收两个参数(value, param),value表示元素的值,param表示参数

* @param {String} message 提示信息

*/

addMethod(name, method, message) {

this.methods[name] = method

this.defaults.messages[name] = message !== undefined ? message : this.defaults.messages[name]

}

/×*

* 判断验证方法是否存在

*/

isValidMethod(value) {

let methods = []

for(let method in this.methods) {

if (method && typeof this.methods[method] === &#39;function&#39;) {

methods.push(method)

}

}

return methods.indexOf(value) !== -1

}

/×*

* 格式化提示信息模板

*/

formatTpl(source, params) {

const that = this

if (arguments.length === 1) {

return function() {

let args = Array.from(arguments)

args.unshift(source)

return that.formatTpl.apply(this, args)

}

}

if (params === undefined) {

return source

}

if (arguments.length > 2 && params.constructor !== Array) {

params = Array.from(arguments).slice(1)

}

if (params.constructor !== Array) {

params = [ params ]

}

params.forEach(function(n, i) {

source = source.replace(new RegExp("{" + i + "}", "g"), function() {

return n

})

})

return source

}

/×*

* 判断规则依赖是否存在

*/

depend(param) {

switch(typeof param) {

case &#39;boolean&#39;:

param = param

break

case &#39;string&#39;:

param = !!param.length

break

case &#39;function&#39;:

param = param()

default:

param = !0

}

return param

}

/×*

* 判断输入值是否为空

*/

optional(value) {

return !this.methods.required(value) && &#39;dependency-mismatch&#39;

}

/×*

* 获取自定义字段的提示信息

* @param {String} param 字段名

* @param {Object} rule 规则

*/

customMessage(param, rule) {

const params = this.messages[param]

const isObject = typeof params === &#39;object&#39;

if (params && isObject) return params[rule.method]

}

/×*

* 获取某个指定字段的提示信息

* @param {String} param 字段名

* @param {Object} rule 规则

*/

defaultMessage(param, rule) {

let message = this.customMessage(param, rule) || this.defaults.messages[rule.method]

let type = typeof message

if (type === &#39;undefined&#39;) {

message = `Warning: No message defined for ${rule.method}.`

} else if (type === &#39;function&#39;) {

message = message.call(this, rule.parameters)

}

return message

}

/×*

* 缓存错误信息

* @param {String} param 字段名

* @param {Object} rule 规则

* @param {String} value 元素的值

*/

formatTplAndAdd(param, rule, value) {

let msg = this.defaultMessage(param, rule)

this.errorList.push({

param: param,

msg: msg,

value: value,

})

}

/×*

* 验证某个指定字段的规则

* @param {String} param 字段名

* @param {Object} rules 规则

* @param {Object} event 表单数据对象

*/

checkParam(param, rules, event) {

// 缓存表单数据对象

this.scope = event

// 缓存字段对应的值

const data = event.detail.value

const value = data[param] || &#39;&#39;

// 遍历某个指定字段的所有规则,依次验证规则,否则缓存错误信息

for(let method in rules) {

// 判断验证方法是否存在

if (this.isValidMethod(method)) {

// 缓存规则的属性及值

const rule = {

method: method,

parameters: rules[method]

}

// 调用验证方法

const result = this.methods[method](value, rule.parameters)

// 若result返回值为dependency-mismatch,则说明该字段的值为空或非必填字段

if (result === &#39;dependency-mismatch&#39;) {

continue

}

// 判断是否通过验证,否则缓存错误信息,跳出循环

if (!result) {

this.formatTplAndAdd(param, rule, value)

break

}

}

}

}

/×*

* 验证所有字段的规则,返回验证是否通过

* @param {Object} event 表单数据对象

*/

checkForm(event) {

this.errorList = []

for (let param in this.rules) {

this.checkParam(param, this.rules[param], event)

}

return this.valid()

}

/×*

* 返回验证是否通过

*/

valid() {

return this.size() === 0

}

/×*

* 返回错误信息的个数

*/

size() {

return this.errorList.length

}

/×*

* 返回所有错误信息

*/

validationErrors() {

return this.errorList

}

}

export default WxValidate

下面小编就给大家介绍一个小程序吧

嗨图功能

微信小程序表单验证怎么弄?

1、专题——DIY图片的模板,点击可以生成使用,分享到朋友圈。

2、分享墙——用户上传的自己DIY作品。

3、立即制作——可以用自己的图来DIY。

4、告诉我——告诉产品的改进,内容的增加。

想要体验怎么制作属于自己个性朋友圈照片的用户,扫一扫下面的二维码就可以啦!还等什么,赶紧扫码体验,开启你的嗨图之旅吧!

微信小程序表单验证怎么弄?
标签: 微信
相关文章: