策略模式

定義

定義一系列算法, 把他們一個個封裝起來,并且能夠相互替換。將不變的部分和變化的部分隔開是每個設計模式的主題,策略模式的目的就是將算法的使用與算法的實現分離開來

策略模式實現表單驗證
<form action="http:// xxx.com/register" id="registerForm" method="post">
    請輸入用戶名:<input type="text" name="userName"/ >
    請輸入密碼:<input type="text" name="password"/ >
    請輸入手機號碼:<input type="text" name="phoneNumber"/ >
    <button>提交</button>
</form>
    ...
<script type="text/javascript">
    var registerForm = document.getElementById('registerForm');

    var strategies = {
        'isNotEmpty': function (val, error) {
            if (val == "") {
                this.focus();
                return error;
            }
        },
        'minLength': function (val, error, length) {
            if (val.length < length) {
                this.focus();
                return error;
            }
        },
        'isMobile': function (val, error) {
            if (!/(^1[3|5|8][0-9]{9}$)/.test(val)) {
                this.focus();
                return error;
            }
        }
    };

    var validataFn = function () {

        var validator = new Validator();

        /*添加規則*/
        validator.add( registerForm.userName, [{
                strategy: 'isNotEmpty',
                errorMsg: '用戶名不能為空'
            }, {
                strategy: 'minLength:6',
                errorMsg: '用戶名長度不能小于 10 位'
            }] 
        );

        var errMsg = validator.start();

        return errMsg;
    }

    function Validator () { 
        this.cache = [];
    }

    /**
     * @params: dom表示表單元素,rule: {strategy: 驗證規則, errMsg: 錯誤信息}
     * 用于將驗證函數添加到數組中
     */
    Validator.prototype.add = function (dom, rule) {
        var self = this;
        
        rule.map(function (val, n) {
            var arrs = [];
            arrs = val.strategy.split(':');
            var strategy = arrs.shift();
            arrs.unshift(val.errorMsg);
            arrs.unshift(dom.value);
            self.cache.push(function(){
                return strategies[strategy].apply(dom, arrs);
            });
        })
    }

    /**
     * 用于返回第一個驗證的錯誤信息
     */
    Validator.prototype.start = function () {
        console.log(this.cache[1]());
        for (var i = 0, fn; fn = this.cache[i++];) {
            var err = fn();
            if(err) {
                return err;
            }
        }
    }

    registerForm.onsubmit = function () {
        var err = validataFn();
        if (err) {
            alert(err);
        }
        return false;
    }
</script>
策略模式的優缺點
優點
  1. 策略模式利用組合、委托和多態等技術和思想,可以有效地避免多重條件選擇語句
  2. 策略模式提供了對開放 — 封閉原則的完美支持,將算法封裝在獨立的 strategy 中,使得它們易于切換,易于理解,易于擴展
  3. 策略模式中的算法也可以復用在系統的其他地方,從而避免許多重復的復制粘貼工作。
  4. 在策略模式中利用組合和委托來讓 Context擁有執行算法的能力,這也是繼承的一種更輕便的替代方案
缺點

使用策略模式會在程序中增加許多策略類或者策略對象。其次,要使用策略模式,必須了解所有的 strategy ,必須了解各個 strategy 之間的不同點,
這樣才能選擇一個合適的 strategy 。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,119評論 6 531
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 98,382評論 3 415
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事?!?“怎么了?”我有些...
    開封第一講書人閱讀 176,038評論 0 373
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,853評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 71,616評論 6 408
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,112評論 1 323
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,192評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,355評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 48,869評論 1 334
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 40,727評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 42,928評論 1 369
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,467評論 5 358
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,165評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,570評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,813評論 1 282
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 51,585評論 3 390
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 47,892評論 2 372

推薦閱讀更多精彩內容

  • 1 場景問題# 1.1 報價管理## 向客戶報價,對于銷售部門的人來講,這是一個非常重大、非常復雜的問題,對不同的...
    七寸知架構閱讀 5,118評論 9 62
  • 1 場景問題 1.1 報價管理 向客戶報價,對于銷售部門的人來講,這是一個非常重大、非常復雜的問題,對不同的客戶要...
    4e70992f13e7閱讀 3,099評論 2 16
  • 本文僅僅為入門,高手勿噴。 實際工作中,我們總會遇到類似如下的需求:某支付系統接入以下幾種商戶進行充值:易寶網易,...
    JarvanMo閱讀 14,245評論 14 26
  • 1.概述 demo地址,歡迎star 例子1: 商場產品銷售:可以正常價格售出,可以打折形式售出,也可以通過積分的...
    barry閱讀 760評論 0 1
  • 策略模式(Strategy)屬于對象行為型設計模式,主要是定義一系列的算法,把這些算法一個個封裝成擁有共同接口的單...
    山的那邊是什么_閱讀 387評論 0 0