JavaScript設計モードのポリシーモードを学ぶ

3713 ワード

不変の部分と変化する部分を区切るのが各デザインモードのテーマです.
  • 本の大通りはローマに通じている.圧縮ファイルなど、zipアルゴリズムを使用したり、gzipアルゴリズムを使用したりすることができます.柔軟で多様で、戦略モデルを採用して解決することができます.

  • 一、定義
    一連のアルゴリズムを定義し、それらを一つ一つカプセル化し、互いに置き換えることができます.ポリシークラスモードに基づくプログラムは、少なくとも2つの部分から構成される.最初の部分は、特定のアルゴリズムをカプセル化し、特定の計算プロセスを担当するポリシークラスのセットです.第2の部分は環境クラス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;
      }
     }
    };
    
    
    //   
    
    
    
    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プログラムの設計を学ぶのに役立つことを願っています.