JS表单验证插件之数据与逻辑分离操作实例分析【
本文实例讲述了JS表单验证插件之数据与逻辑分离操作。分享给大家供大家参考,具体如下
之前已经写过一个了,为什么还会重复造轮子呢?第一个问题是代码结构比较乱,虽然通过原型继承的写法将处理分层,但业务逻辑和数据结构混杂在一起,导致第二个问题——可扩展性和灵活性差。
认真分析表单验证的过程,可以分为两步怎么验证和如何验证。怎么验证是数据层面的问题,如何验证是业务逻辑层面的问题。
点击 查看源码
策略模式将对象和规则区分
如何让算法(数据层)和对象(逻辑层)分开来,使得算法可以独立于使用它的客户而变化?这里引入策略模式。
什么是策略模式
定义一系列的算法,把每一个算法封装起来, 并且使它们可相互替换。本模式使得算法可独立于使用它的客户而变化。
即策略模式把对象本身和运算规则区分开来,其功能非常强大,因为这个设计模式本身的核心思想就是面向对象编程的多形性的思想。
关于策略模式的更多定义,
狼蚁网站SEO优化我们就开始运用策略模式来解决代码分层问题。
理想中的插件调用
在开始代码之前,我们希望用更简单的方式调用插件。
// 获取表单form元素 var form = document.getElementById('myForm'); // 创建表单校验实例 var validation = new FormValidator(); // 编写校验配置 validation.add(form.username, 'isEmpty', '用户名不能为空s'); validation.add(form.password, 'minLength: 6', '密码长度不能小于6个字符'); validation.add(form.password2, 'isEqualTo: password', '密码不一致'); validation.add(form.mobile, 'isMobile', '请填写正确的手机号'); // 开始校验,并接收错误信息 $('#submit-btn').click(function() { var errorMsg = validation.start(); // 如果有错误信息输出,说明校验未通过 if(errorMsg){ console.log(errorMsg); return false; } })
add()方法参数说明
1、 参数1需要验证的表单项DOM元素,form[name属性]
2、 参数2验证方法,用冒号分割,冒号后的值为方法的参数(可选)
3、 参数3错误提示信息
编写验证函数
我们开始运用策略模式编写代码。第一步,只编写无关业务逻辑的验证函数算法,即数据层
var VerifyPolicies = { isEmpty: function(value, errMsg) { if(value == '') return errMsg; }, // 最小长度 minLength: function(value, length, errMsg) { if (value.length < length) return errMsg; }, // 手机号码 isMobile: function(value, errMsg) { if(!/^1[34578]\d{9}$/.test(value)) return errMsg; }, // 是否相等 isEqualTo: function (value, toDom, errMsg) { var toValue = document.getElementById(toDom).value; if(value !== toValue) return errMsg; } };
编写验证逻辑
function FormValidator(VerifyPolicy) { this.verifyPolicies = VerifyPolicy ? VerifyPolicy : VerifyPolicies; // 待执行的验证函数数组 this.validateFn = []; } FormValidator.prototype.add = function(dom, rules, errMsg) { var _this = this; this.validateFn.push(function() { var args = []; var rule = rules.split(':'); var ruleName = rule[0]; var ruleParam = rule[1]; var value = dom.value; args.push(value); if(ruleParam) args.push(ruleParam.trim()); args.push(errMsg); // 这里调用apply只是为了传参,如果支持ES6,也可以这样做 // return _this.verifyPolicies[ruleName](...args) return _this.verifyPolicies[ruleName].apply(null, args); }) }; FormValidator.prototype.start = function() { var fn = this.validateFn; for(var i =0, len = fn.length; ; i++) { var msg = fn[i](); if(msg) return msg; } };
至此,整个表单验证已经初步完成,在此方法之上,可以随意添加方法了。
感兴趣的朋友可以使用在线HTML/CSS/JavaScript代码运行工具测试上述代码运行效果。
更多关于JavaScript相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程