成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

讀書筆記之策略模式

smartlion / 1722人閱讀

摘要:將不變的部分和變化的部分分割開始每個設計模式的主題,策略模式的目的就是將算法的使用與算法的實現分離開來。結合策略模式,可以把判斷這一部分函數里提取出來重新封裝,提高代碼的復用性和可讀性。

最近在看《javascript設計模式與開發(fā)實踐》。

var calc = function(level,salary){
         if(level === "A"){
            return 3*salary
         }
         if(level === "B"){
            return 2*salary
         }
         if(level === "C"){
            return 1*salary
         }
}

這段代碼看起來十分簡單,但是隨著后期的拓展,要添加更多的if語句,calc函數會變得更加龐大,不易于維護。
如果我要修改原有的計算分之,可能每次都要修改calc這個方法。實際上,這個calc這個方法的設計初衷只是為了返回 績效工資。
在整個代碼的其它部分,可能還需要這個計算方法,難道還要copy一份過去么,那么同樣的修改要修改兩塊代碼。

用策略模式來重構代碼

策略模式指的是定義一系列的算法,把他們一個個都封裝起來。將不變的部分和變化的部分分割開始每個設計模式的主題,策略模式的目的就是將算法的使用與算法的實現分離開來。

再說上邊的需求,我們簡單思考下,其實變化的部分就是員工的等級和工資,而我們的目的就是返回績效工資這部分是不變的

//  根據員工的level和salary 金額的計算
var straigies = {
    “A”: function(salary){
        return fn*3
    },
    “B”: function(salary){
        return fn*2
    },
    “C”: function(salary){
        return fn*1
    }
}
//不變的部分
var calc = function(level,salary){
     return straigies[level](salary)
}
// 執(zhí)行
calc("A",5000)    // => 15000

比較下兩段代碼,不見了不友好的 if判斷,算法(策略)都放在了straigies 中,后續(xù)需求 只需要維護straigies對象即可。

用策略模式來重構表單驗證

很多需要提交表單的業(yè)務場景,都需要如下結構的代碼

$("submitBtn").on("click",functioin(){
    if($name.value().length < 6){
         console.log("用戶名長度不能少于6")
    }
   if($phone.value() != ""){
        console.log("電話號碼不能為空")
 }
  ajaxFn()
})

隨著 判斷條件的增加,函數的結構會越來越臃腫龐大,而需要修改判斷的條件,就又要深入指定的if判斷去篩選,單純的新增規(guī)則在這個函數里,復用性太差。結合策略模式,可以把if判斷這一部分 函數里提取出來重新封裝,提高代碼的復用性和可讀性。

對代碼結構的期望

$("submitBtn").on("click",functioin(){
  var form = document.querySelector(".form");
  var validator = new validator ();
  validator.addrules(form.username,"isNonEmpty","不能為空")
  validator.addrules(form.phone,"minLength:6","最少為6位")
  var erroMsg = validator.start();
  if(erroMsg){
     alert(validator);
     return false
  }
  ajaxFn()
})

我們先封裝策略類

var stratigies = {
    isNonEmpty: function(value,erromsg){
          if(value == ""){
          return erromsg
        }
    },
  minlength: function(value,length,erromsg){
       if(value.length < length){
          return erromsg
      }
 }
}

封裝 驗證(validator類)

var Validator = function(){
  this.cache = [] //用來緩存
}
Validator.prototype.add = function(item,rule,erroMsg){
  var arg = rule.split(":") // rule= >  "isEmpty" => ["isEmpty"] ||  "minLength:5"=> ["minlength", “5”];
  this.cache.push(function(){
      var strategy = arg.shift();  // =>"isEmpty" || minLength
      arg.unshift(item.value);  //[value] || [value,5]
      arg.push(errMsg)// [value,errMsg] || [value,5,errMsg]
      return  stratigies[strategy].apply(item,arg)
  })
}
//start方法就是遍歷這個Validator里緩存的方法并執(zhí)行
Validator.prototype.start = function(){
  for(var i=0;i開始校驗,
      if(msg){
         return msg   // 如果msg有值 就說明驗證不通過,跳出循環(huán)
      }
  }
}

此時,如果需要添加規(guī)則 或是修改驗證規(guī)則,就很簡單了
我們可以在stratigies里添加策略,也可以在 提交表單的函數里,新增或者修改規(guī)則

validator.addrules(form.phone,"minLength:6") =》 validator.addrules(form.phone,"minLength:10")

很蛋疼的是,對用戶名判斷只能一次輸入一種規(guī)則,如果需要加一種判斷規(guī)則,我就要在add一次strategy,
書中提供了進一步的拓展。

//預期
  validator.addrules(form.username,[
   {
      "erroMsg": "不能為空",
      "strategy": "isNonEmpty"
    },
   {
      "erroMsg": "最小為6位",
      "strategy": "minLength:6"
    }
])

將策略用數組的方式傳入validator對象里,緩存在this.cache里,只需要調整對應的add方法就可以

//old type
Validator.prototype.add = function(item,rule,erroMsg){
  var arg = rule.split(":") // rule= >  "isEmpty" => ["isEmpty"] ||  "minLength:5"=> ["minlength", “5”];
  this.cache.push(function(){
      var strategy = arg.shift();  // =>"isEmpty" || minLength
      arg.unshift(item.value);  //[value] || [value,5]
      arg.push(errMsg)// [value,errMsg] || [value,5,errMsg]
      return  stratigies[strategy].apply(item,arg)
  })
}
// new Type
Validator.prototype.add = function(item,rules){
   var  _this = this; //保存this指針   for循環(huán)里的的自執(zhí)行函數的this指向window,用_this修復指針
  //遍歷rules
 for(var i = 0;i  "isEmpty" => ["isEmpty"] ||  "minLength:5"=> ["minlength", “5”];
       var  errMsg = rule.errMsg;
      _this.cache.push(function(){
            var strategy = arg.shift();  // =>"isEmpty" || minLength
            arg.unshift(item.value);  //[value] || [value,5]
            arg.push(errMsg)// [value,errMsg] || [value,5,errMsg]
            return  stratigies[strategy].apply(item,arg)
         })
      })(rule)
  }
}

文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規(guī)行為,您可以聯系管理員刪除。

轉載請注明本文地址:http://systransis.cn/yun/91098.html

相關文章

  • 《JavaScript設計模式與開發(fā)實踐》讀書筆記

    摘要:訂閱模式的一個典型的應用就是后面會寫一篇相關的讀書筆記。享元模式享元模式的核心思想是對象復用,減少對象數量,減少內存開銷。適配器模式對目標函數進行數據參數轉化,使其符合目標函數所需要的格式。 設計模式 單例模式 JS的單例模式有別于傳統(tǒng)面向對象語言的單例模式,js作為一門無類的語言。使用全局變量的模式來實現單例模式思想。js里面的單例又分為普通單例和惰性單例,惰性單例指的是只有這個實例...

    Panda 評論0 收藏0
  • JavaScript設計模式策略模式

    摘要:設計模式與開發(fā)實踐讀書筆記。策略模式可以有效避免多重條件選擇語句。當然,策略模式也有一些缺點增加了許多策略類或者策略對象。要使用策略模式,必須了解所有的,違反了最少知識原則。至此,回家咯附設計模式之發(fā)布訂閱模式觀察者模式 《JavaScript設計模式與開發(fā)實踐》讀書筆記。這本書挺好的,推薦。 俗話說,條條大路通羅馬。在現實生活中,我們可以采用很多方法實現同一個目標。比如我們先定個小目...

    go4it 評論0 收藏0
  • 流暢的python讀書筆記-第六章-使用一等函數實現設計模式

    摘要:在復雜的情況下,需要具體策略維護內部狀態(tài)時,可能需要把策略和享元模式結合起來。函數比用戶定義的類的實例輕量,而且無需使用享元模式,因為各個策略函數在編譯模塊時只會創(chuàng)建一次。 一等函數實現設計模式 經典的策略模式定義 定義一系列算法,把它們一一封裝起來,并且使它們可以相互替換。本模式使得算法可以獨立于使用它的客戶而變化。 案例 假如一個網店制定了下述折扣規(guī)則。 有 1000 或以上積分...

    cnsworder 評論0 收藏0
  • 讀書筆記】JVM垃圾收集與內存分配策略

    摘要:堆和方法區(qū)只有在程序運行時才能確定內存的使用情況,垃圾回收器所關注的主要就是這部分內存。虛擬機會根據當前系統(tǒng)的運行情況收集性能監(jiān)控信息,動態(tài)調整比率參數以提供最合適的停頓時間或最大的吞吐量。 Tip:內容為對《深入理解Java虛擬機》(周志明 著)第三章內容的總結和筆記。這是第一次拜讀時讀到的一些重點,做個分享,也為后面再次閱讀和實踐做保障。 3.1 概述 程序計數器、虛擬機棧、本地...

    mcterry 評論0 收藏0

發(fā)表評論

0條評論

smartlion

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<