前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >JavaScript设计模式--策略模式

JavaScript设计模式--策略模式

作者头像
奋飛
修改2020-10-21 09:50:06
3270
修改2020-10-21 09:50:06
举报
文章被收录于专栏:Super 前端Super 前端

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

条条大路通罗马。我们经常会遇到解决一件事情有多种方案,比如压缩文件,我们可以使用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:\\/\\/)?([\\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();
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2015年12月20日,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 一、定义
  • 二、示例
  • 三、延伸:表单验证
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档