学习JavaScript设计模式之策略模式

把不变的部分和变化的部分隔开是每个设计模式的主题。

一、定义

定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。 基于策略类模式的程序至少由两部分组成。第一个部分是一组策略类,策略类封装了具体的算法,并负责具体的计算过程。第二个部分是环境类Context,Context接收客户的请求,随后把请求委托给某一个策略类。

二、示例

计算奖金。绩效为S的发放4倍工资,绩效为A的发放3倍工资,绩效为B的发放2倍工资。

// 接收请求
var calculateBonus = function(level,salary) {
return strategieslevel;
};

// 测试
console.log(calculateBonus("S",20000));
console.log(calculateBonus("A",20000));
console.log(calculateBonus("B",20000));

三、延伸:表单验证

<div class="jb51code">
<pre class="brush:js;">
/ 校验策略对象 /
var validateStrategies = {
isEmpty: function (val,errorMsg) {
if (!val) {
return errorMsg;
}
},isURL: function (val,errorMsg) {
if (!new RegExp("^(http:\/\/|https:\/\/)?([\w\-]+\.)+[\w\-]+(\/[\w\-\.\/?\@\%\!\&=\+\~\:\#\;\,])?$").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,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">邮箱:<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程序设计有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐


js中event的用法
js中能调用python吗
js中split的用法
js怎么设置边框样式
js中截取字符串的方法
js中innerhtml的用法
javascript的成熟分类方式有哪些
js中document是什么意思
js怎样让div中的文字居中
js中怎样定义一个对象
javascript的成熟分类介绍
js中parseint什么意思
js中字符串如何排序
void在js中是什么意思
js中如何定义函数
js中arguments是什么意思
js中什么是同步和异步
js中如何sleep一秒
js中ui函数是什么意思
js中如何遍历数组