zhichi_admin 发表于 2017-1-17 18:11:47

[插件]自己造的小轮子:表单验证


:shutup:简单的表单验证,也不算是验证了,只是封装了一下提示消息,免得自己去手动写if else(大家都懂吧),用起来还行吧,自己动手丰衣足食。

代码示例:
Skip to content
This repository
Search
Pull requests
Issues
Gist
@chuxue2005
Watch 4
Unstar 30
Fork 7 skyvow/m-mall
CodeIssues 1Pull requests 0Projects 0WikiPulseGraphs
Branch: master Find file Copy pathm-mall/helpers/WxValidate.js
f797de02 hours ago
@skyvow skyvow update validate
1 contributor
RawBlameHistory   
378 lines (347 sloc)8.98 KB
/**
* 创建验证字段的工厂函数
*
* @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) || /^+@(?:{0,61})?(?:\.(?:{0,61})?)*$/.test(value)
                        },
                        /**
                         * 验证手机格式
                         */
                        tel(value) {
                              return that.optional(value) || /^1\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|2\d|3)(?:\.\d{1,3}){2})(?:\d?|1\d\d|2\d|22)(?:\.(?:1?\d{1,2}|2\d|25)){2}(?:\.(?:\d?|1\d\d|2\d|25))|(?:(?:-*)*+)(?:\.(?:-*)*+)*(?:\.(?:{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)[\/\-](0?||3)$/.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) || /^\d{5}\d{3}((0\d)|(1))((\d)|3)\d{3}(|X)$/.test(value)
                        },
                        /**
                         * 验证两个输入框的内容是否相同
                         */
                        equalTo(value, param) {
                              return that.optional(value) || value === that.scope.detail.value
                        },
                        /**
                         * 验证是否包含某个值
                         */
                        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
                        },
                        /**
                         * 验证一个长度范围
                         */
                        rangelength(value, param) {
                              return that.optional(value) || (value.length >= param && value.length <= param)
                        },
                        /**
                         * 验证最小值
                         */
                        min(value, param) {
                              return that.optional(value) || value >= param
                        },
                        /**
                         * 验证最大值
                         */
                        max(value, param) {
                              return that.optional(value) || value <= param
                        },
                        /**
                         * 验证一个值范围
                         */
                        range(value, param) {
                              return that.optional(value) || (value >= param && value <= param)
                        },
                }
      }

      /**
         * 添加自定义验证方法
         * @param {String} name 方法名
         * @param {Function} method 函数体,接收两个参数(value, param),value表示元素的值,param表示参数
         * @param {String} message 提示信息
         */
      addMethod(name, method, message) {
                this.methods = method
                this.defaults.messages = message !== undefined ? message : this.defaults.messages
      }

      /**
         * 判断验证方法是否存在
         */
      isValidMethod(value) {
                let methods = []
                for(let method in this.methods) {
                        if (method && typeof this.methods === 'function') {
                              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 'boolean':
                              param = param
                              break
                        case 'string':
                              param = !!param.length
                              break
                        case 'function':
                              param = param()
                        default:
                              param = !0
                }
                return param
      }

      /**
         * 判断输入值是否为空
         */
      optional(value) {
                return !this.methods.required(value) && 'dependency-mismatch'
      }

      /**
         * 获取自定义字段的提示信息
         * @param {String} param 字段名
         * @param {Object} rule 规则
         */
      customMessage(param, rule) {
                const params = this.messages
                const isObject = typeof params === 'object'
                if (params && isObject) return params
      }

      /**
         * 获取某个指定字段的提示信息
         * @param {String} param 字段名
         * @param {Object} rule 规则
         */
      defaultMessage(param, rule) {
                let message = this.customMessage(param, rule) || this.defaults.messages
                let type = typeof message
               
                if (type === 'undefined') {
                        message = `Warning: No message defined for ${rule.method}.`
                } else if (type === 'function') {
                        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 || ''
               
                // 遍历某个指定字段的所有规则,依次验证规则,否则缓存错误信息
                for(let method in rules) {

                        // 判断验证方法是否存在
                        if (this.isValidMethod(method)) {

                              // 缓存规则的属性及值
                              const rule = {
                                        method: method,
                                        parameters: rules
                              }

                              // 调用验证方法
                              const result = this.methods(value, rule.parameters)
                                 
                              // 若result返回值为dependency-mismatch,则说明该字段的值为空或非必填字段
                              if (result === 'dependency-mismatch') {
                                        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, event)
                }

                return this.valid()
      }

      /**
         * 返回验证是否通过
         */
      valid() {
                return this.size() === 0
      }

      /**
         * 返回错误信息的个数
         */
      size() {
                return this.errorList.length
      }

      /**
         * 返回所有错误信息
         */
      validationErrors() {
                return this.errorList
      }
}

export default WxValidate
Contact GitHub API Training Shop Blog About
© 2016 GitHub, Inc. Terms Privacy Security Status Help


jerry369 发表于 2020-4-25 14:23:42

我有流量,你有产品,我们就可以合作,有意的个人开发者朋友可以联系微信号jim20180688,详聊
页: [1]
查看完整版本: [插件]自己造的小轮子:表单验证