幽灵资源网 Design By www.bzswh.com
把不变的部分和变化的部分隔开是每个设计模式的主题。
- 条条大路通罗马。我们经常会遇到解决一件事情有多种方案,比如压缩文件,我们可以使用zip算法、也可以使用gzip算法。其灵活多样,我们可以采用策略模式解决。
一、定义
定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。
基于策略类模式的程序至少由两部分组成。第一个部分是一组策略类,策略类封装了具体的算法,并负责具体的计算过程。第二个部分是环境类Context,Context接收客户的请求,随后把请求委托给某一个策略类。
二、示例
计算奖金。绩效为S的发放4倍工资,绩效为A的发放3倍工资,绩效为B的发放2倍工资。
var strategies = {
"S": function(salary) {
return salary * 4;
},
"A": function(salary) {
return salary * 3;
},
"B": function(salary) {
return salary * 2;
}
};
// 接收请求
var calculateBonus = function(level, salary) {
return strategies[level](salary);
};
// 测试
console.log(calculateBonus("S", 20000));
console.log(calculateBonus("A", 20000));
console.log(calculateBonus("B", 20000));
三、延伸:表单验证
/* 校验策略对象 */
var validateStrategies = {
isEmpty: function (val, errorMsg) {
if (!val) {
return errorMsg;
}
},
isURL: function (val, errorMsg) {
if (!new RegExp("^(http:\\/\\/|https:\\/\\/)").test(val)) {
return errorMsg;
}
},
isEmail: function (val, errorMsg) {
if (!new RegExp('\\w+((-\\w+)|(\\.\\w+))*\\@[A-Za-z0-9]+((\\.|-)[A-Za-z0-9]+)*\\.[A-Za-z0-9]+').test(val)) {
return errorMsg;
}
},
isMaxLength: function (val, length, errorMsg) {
if (val.length > length) {
return errorMsg;
}
},
isMinLength: function (val, length, errorMsg) {
if (val.length < length) {
return errorMsg;
}
}
};
/* validator类 */
var validator = function () {
// 缓存验证策略
this.cache = [];
};
/**
* 添加要验证的策略
* @param dom 要验证的dom元素
* @param rules 验证规则
*/
validator.prototype.add = function (dom, rules) {
var self = this;
for (var i = 0, rule; rule = rules[i++];) {
(function (rule) {
var strategyAry = rule.strategy.split(":"); // ["isMaxLength", "10"]
var errorMsg = rule.errorMsg; // "内容长度不能超过10"
self.cache.push(function () {
var strategy = strategyAry.shift(); // "isMaxLength"
strategyAry.unshift(dom.value); // ["1@qq", "10"]
strategyAry.push(errorMsg); // ["1@qq", "10", "内容长度不能超过10"]
return validateStrategies[strategy].apply(dom, strategyAry);
});
})(rule);
}
};
/* 开始校验 */
validator.prototype.start = function () {
for (var i = 0, validateFunc; validateFunc = this.cache[i++];) {
var errorMsg = validateFunc();
if (errorMsg) {
return errorMsg;
}
}
};
// 测试
<label for="email">邮箱:</label><input type="text" name="email" value="1@qq">
var validatorInstance = new validator();
validatorInstance.add(
document.getElementsByName("email")[0],
[{
strategy: "isEmpty",
errorMsg: "内容不能为空"
},{
strategy: "isMaxLength:10",
errorMsg: "内容长度不能超过10"
},{
strategy: "isEmail",
errorMsg: "email格式不对"
}]);
errorMsg = validatorInstance.start();
希望本文所述对大家学习javascript程序设计有所帮助。
幽灵资源网 Design By www.bzswh.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
幽灵资源网 Design By www.bzswh.com
暂无评论...
《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线
暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。
艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。
《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。