js设计模式总结-策略模式
策略模式
要解决的问题
当解决一个问题有多种方法时,选择使用哪种方法时就少不了要用大量的if语句进行判断,如果将这些方法的实现和判断语句放在一起实现就会产生问题,
比如增加一种的新的方法时,就不得不再去写一条if语句,这不符合开闭原则,也不方便复用,因此策略模式主要解决的是算法的实现和算法的使用的过度耦合问题。
实现原理
将每个算法的实现封装起来,并可以相互替换(因为它们有共同的目的),通过统一的上下文调用,一方面解决了耦合问题,另一方面增强了代码的复用能力
实践中的应用
表单的验证
表单验证涉及到多个判断语句,一般我们会这样实现
var form = document.getElementById('myform')
form.onsubmit = function() {
if (form.username.value === '') {
alert('请输入用户名')
return false
}
if (form.password.value === '') {
alert('请输入密码')
return false
}
if (form.password.value.length < 8) {
alert('密码不小于8位')
return false
}
}
当增加新的字段或者变换新的验证规则时就不得不去修改if语句或者增加新的if语句,而且当别的表单也需要这样验证时没法复用。
所以采用策略模式来实现
// 策略对象,封装一系列的策略
var rules = {
NOT_EMPTY: function(value, errorMsg) {
value = '' + value
if (value === '') {
return errorMsg
}
},
NOT_LESS: function(value, length, errorMsg) {
value = '' + value
if (value.length < length) {
return errorMsg
}
}
}
// 验证器的实现
var Validator = function(rules) {
this.rules = rules
// 保存着验证规则
this.cache = []
}
// 添加规则
Validator.prototype.add = function(value, rule, errorMsg) {
var ruleArray = rule.split(':')
var self = this
if (ruleArray.length === 1) {
// 利用闭包来保存外部的值
this.cache.push(function() {
return self.rules[rule](value, errorMsg)
})
} else if (ruleArray.length === 2) {
this.cache.push(function() {
return self.rules[ruleArray[0]](value, ruleArray[1], errorMsg)
})
}
}
Validator.prototype.start = function() {
var errorMsg = ''
for (var r = 0; r < this.cache.length; r++) {
var errorMsg = this.cache[r]()
if (errorMsg) {
return errorMsg
}
}
}
var form = document.getElementById('myform')
form.onsubmit = function() {
var v = new Validator(rules)
v.add(form.username.value, 'NOT_EMPTY', '请输入用户名')
v.add(form.password.value, 'NOT_LESS:8', '密码不少于8位')
var errorMsg = v.start()
if (errorMsg) {
alert(errorMsg)
return false
}
}
根据上述代码,如果我们添加新的验证规则,只需要在rules添加新的验证函数就可,如果添加新的字段,只需要add进Validator中即可,实现了算法的实现与使用的分离,符合开闭原则。
js设计模式总结-策略模式的更多相关文章
- JS 设计模式三 -- 策略模式
策略模式 概念 定义一系列算法,把它们一个个封装起来. 将算法的使用与算法的实现分离开来 实现 // 加权映射关系 var levelMap = { S: 10, A: 8, B: 6, C: 4 } ...
- 浅谈js设计模式之策略模式
策略模式有着广泛的应用.本节我们就以年终奖的计算为例进行介绍. 很多公司的年终奖是根据员工的工资基数和年底绩效情况来发放的.例如,绩效为 S的人年终奖有 4倍工资,绩效为 A的人年终奖有 3倍工资,而 ...
- JavaScript设计模式之策略模式(学习笔记)
在网上搜索“为什么MVC不是一种设计模式呢?”其中有解答:MVC其实是三个经典设计模式的演变:观察者模式(Observer).策略模式(Strategy).组合模式(Composite).所以我今天选 ...
- JavaScript设计模式之策略模式【组合委托】
前言:语言只是工具,思想才是核心 今天要总结的是 策略模式 策略在开发中的应用非常广泛,所以也是非常常见且使用的设计模式. 在实际开发中,往往在实现一个功能时,有多种解决方案可行. 常见场景: 解压: ...
- 设计模式:策略模式(Strategy)
定 义:它定义了算法家族,分别封装起来,让它们之间可以互相替换,此模式让算法的变化, 不会影响到使用算法的客户. 示例:商场收银系统,实现正常收费.满300返100.打8折.......等不同收费 ...
- JS设计模式——5.单体模式
JS设计模式——5.单体模式 http://www.cnblogs.com/JChen666/p/3610585.html 单体模式的优势 用了这么久的单体模式,竟全然不知!用它具体有哪些好处呢? ...
- PHP设计模式之策略模式
前提: 在软件开发中也常常遇到类似的情况,实现某一个功能有多种算法或者策略,我们可以根据环境或者条件的不同选择不同的算法或者策略来完成该功能.如查 找.排序等,一种常用的方法是硬编码(Hard Cod ...
- 乐在其中设计模式(C#) - 策略模式(Strategy Pattern)
原文:乐在其中设计模式(C#) - 策略模式(Strategy Pattern) [索引页][源码下载] 乐在其中设计模式(C#) - 策略模式(Strategy Pattern) 作者:webabc ...
- JavaScript设计模式之策略模式
所谓"条条道路通罗马",在现实中,为达到某种目的往往不是只有一种方法.比如挣钱养家:可以做点小生意,可以打分工,甚至还可以是偷.抢.赌等等各种手段.在程序语言设计中,也会遇到这种类 ...
随机推荐
- zookeeper清除事物日志
dataDir=/data/zookeeper/data dataLogDir=/data/zookeeper/log zk事物日志(快照)存放目录,高负荷工作的时候,会产生大量的日志,需 ...
- using的作用
using (ServiceHost host = new ServiceHost(typeof(OperationService))) 这样写代码有何好处?using的作用范围自动回收垃圾,在这个范 ...
- Windows Azure - Troubleshooting & Debugging: Role Recycling
每年总会碰到几次Role Recycling,处理完记录下 :) 1. 和往常一样先排查系统日志,修复异常.> 没效果 :( 2. 排查Event Viewer中的Logs,没有发现比较奇怪Lo ...
- Day 6
- 流量三角形:并非简单的"统计学"
又忙了一周多,今天过来再整理一些东西.国内做产险精算的,准备金的居多,从精算部落中的帖子的跟帖情况可见一斑.既然准备金更容易受到大家的关注,今天再整理一个关于准备金的个人看法,给精算部落收敛一下人气, ...
- FusionCharts饼图的图例属性
showLegend 是否在图表中显示图例 legendPosition 图例可以显示在图表的底部(BOTTOM)或右侧(RIGHT) legendCaption 可以为图例整体定义一个标题 lege ...
- Struts2批量验证(POC)
only poc , 再据结果利用EXP进一步测试: 支持 -u 单个url; -f 文本批量URL导入 url列表格式是https://www.baidu.com #! /usr/bin/env p ...
- UIPickerView滚轮选择器视图
//必须实现两个协议 //数据源协议必须实现的两个方法 //选取器的输出借口singlePicker,并在故事版中选择该选取器将dataSource和delegate拖入视图控制器与之关联 //@pr ...
- 【转载】jQuery动画连续触发、滞后反复执行解决办法
转载: http://www.cnblogs.com/yuejin/archive/2012/12/18/2822595.html jQuery中slideUp .slideDown.animate等 ...
- .net动态类型在处理json数据方面的应用
我们在.net中处理json数据时,经常需要定义相应的类.比如json数据:{ "name" : "hello", "age" : 18 } ...