把不变的部分和变化的部分隔开是每个设计模式的主题。
一、定义
定义一系列的算法,把它们一个个封装起来,并且使它们可以相互替换。
基于策略类模式的程序至少由两部分组成。第一个部分是一组策略类,策略类封装了具体的算法,并负责具体的计算过程。第二个部分是环境类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:\\\\/\\\\/)?([\\\\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, 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程序设计有所帮助。
本文地址:https://www.stayed.cn/item/6059
转载请注明出处。
本站部分内容来源于网络,如侵犯到您的权益,请 联系我