摘要:一策略模式定義把一些小的算法封裝起來使他們之間可以相互替換把代碼的實現和使用分離開來利用策略模式實現小方塊緩動代碼代碼動畫已消耗時間原始位置目標位置持續時間小球運動的時間要改變的屬性例如緩動算法記錄開始位置并設置定時器是否有要執行的
一.策略模式
1.定義:把一些小的算法,封裝起來,使他們之間可以相互替換(把代碼的實現和使用分離開來)
2.利用策略模式實現小方塊緩動
html代碼:
js代碼:
var container = document.getElementById("container"); container.style.height = window.innerHeight +"px"; var tween = {//t動畫已消耗時間、b原始位置、c目標位置、d持續時間 linear:function(t,b,c,d){ return c*t/d+b; }, easeIn:function(t,b,c,d){ return c*(t/=d)*t+b; }, strongEaseIn:function(t,b,c,d){ return c*(t/=d)*t*t*t*t+b; }, strongEaseOut:function(t,b,c,d){ return c*((t=t/d-1)*t*t*t*t+1)+b; }, sineaseIn:function(t,b,c,d){ return c*(t/=d)*t*t+b; }, sineaseOut:function(t,b,c,d){ return c*((t=t/d-1)*t*t+1)+b; } }; var animate = function(dom){ this.dom = dom; this.startTime = 0; this.startPos = 0; this.endPos = 0; this.duration = 0;//小球運動的時間 this.propertyName = null;//要改變的css屬性,例如top,left this.easing=null;//緩動算法 }; animate.prototype.start = function(endPos,duration,propertyName,easing){ //記錄開始位置,并設置定時器是否有要執行的步數 this.startTime = new Date(); this.startPos = this.dom.getBoundingClientRect()[propertyName]; this.endPos = endPos; this.duration = duration; this.propertyName = propertyName; this.easing = tween[easing]; var setTime = setInterval(function(){ if(this.step()){ clearsetInterval(setTime); } this.step(); }.bind(this),20) } animate.prototype.step = function(){//動畫執行一步需要的操作 var t = +new Date(); if(t>this.startTime+this.duration){ this.update(this.endPos); return false; } var pos = this.easing(t-this.startTime,this.startPos,this.endPos,this.duration);//t動畫已消耗時間、b原始位置、c目標位置、d持續時間 this.update(pos); } animate.prototype.update = function(pos){//更新div的css屬性 if(pos > window.innerWidth || pos>window.innerHeight){ this.dom.style[this.propertyName] = this.endPos +"px"; return false; } this.dom.style[this.propertyName] = pos +"px"; } //調用 var move = document.getElementById("move"); var a = new animate(move); a.start(100,1000,"bottom","sineaseIn")
3.優缺點
優點:避免多重條件判斷語句;遵循開放-封閉原則,具有較好的擴展性,便于切換;可復用性;
缺點:違背最少知識原則(向用戶暴露所有的實現)
1.定義:允許一個對象在其狀態改變時改變他的行為,對象看起來視乎修改了他的類
2.狀態模式例子:電源開關三種狀態的互相變化(狀態驅動行為)
var Light = function(){ this.offState = new offLightState(this); this.weakState = new weakLightState(this); this.strongState = new strongLightState(this); this.button = null; } Light.prototype.start = function(){ this.button = document.getElementById("change"); this.current = this.offState; this.button.onclick = function(){ this.current.btnPressed(); }.bind(this); } Light.prototype.setState = function(newState){//改變狀態 this.current = newState; } //狀態模式的關鍵是把每種狀態都封裝成一個類 var offLightState = function(light){ this.light = light; }; offLightState.prototype.btnPressed = function(){ console.log("調弱"); this.light.setState(this.light.weakState); } var weakLightState = function(light){ this.light = light; }; weakLightState.prototype.btnPressed = function(){ console.log("調強"); this.light.setState(this.light.strongState); } var strongLightState = function(light){ this.light = light; }; strongLightState.prototype.btnPressed = function(){ console.log("關閉"); this.light.setState(this.light.offState); } var light = new Light(); light.start();//調弱 調強 關閉
3.狀態模式是狀態機的一種實現方式,還可以直接將狀態委托給字面量,利用Function.prototype.call()調用,達到和狀態模式一樣的效果
var FMC = { on:{ buttonWasPressed:function(){ console.log("變弱") this.current = FMC.weak; } }, weak:{ buttonWasPressed:function(){ console.log("變強") this.current = FMC.strong; } }, strong:{ buttonWasPressed:function(){ console.log("變更強") this.current = FMC.superstrong; } }, superstrong:{ buttonWasPressed:function(){ console.log("關閉") this.current = FMC.off; } }, off:{ buttonWasPressed:function(){ console.log("打開") this.current = FMC.on; } } } var light = function(){ this.current = FMC.off; this.button = null; } light.prototype.start = function(){ this.button = document.getElementById("change"); console.log("current",this.current) this.button.onclick = function(){ this.current.buttonWasPressed.call(this); }.bind(this); } var l = new light(); l.start();
4.優缺點
優點:可擴展性較好,可以方便的增加新的狀態;相比冗余的if else判斷,狀態模式將邏輯封裝在類中,避免Context無限膨脹
缺點:代碼邏輯分散在各個類中,造成邏輯分散的問題
相同點:這兩種模式都只有一個上下文、一些策略類或者是狀態類,上下文把請求委托給這些類來執行
不同點:這兩種模式的目的是不同的;策略模式的策略類之間是相互平行平等的,而狀態模式的狀態類把狀態和行為封裝到一起,把邏輯實現封裝到類中,狀態之間的切換也早被規定完成.
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/52434.html
摘要:一策略模式定義把一些小的算法封裝起來使他們之間可以相互替換把代碼的實現和使用分離開來利用策略模式實現小方塊緩動代碼代碼動畫已消耗時間原始位置目標位置持續時間小球運動的時間要改變的屬性例如緩動算法記錄開始位置并設置定時器是否有要執行的 一.策略模式 1.定義:把一些小的算法,封裝起來,使他們之間可以相互替換(把代碼的實現和使用分離開來)2.利用策略模式實現小方塊緩動 html代碼: ...
摘要:推文用設計模式解構三國是一種什么體驗行為型設計模式一策略模式工廠模式優化結構狀態模式隨著狀態改變而改變行為。推文狀態機與狀態模式責任鏈模式多個對象依次處理請求前者指定后者。代理模式代理針對一個對象,為了增加控制等中介雙方都是多個,為了解耦。 策略模式 選擇使用封裝好的一系列算法,可相互替換。 類比:商店[Context]買完衣服買單[Stratege](現金[Concrete Stra...
摘要:抽象工廠模式將具有共同主題的對象工廠分組。對可重用性和可維護性設計模式的高層考慮創造性模式工廠方法模式也稱為虛擬構造器意圖定義一個用于創建對象的接口,但讓子類決定實例化哪個類。 大綱 創造性模式 工廠方法模式創建對象而不指定要創建的確切類。 抽象工廠模式將具有共同主題的對象工廠分組。 Builder模式通過分離構造和表示來構造復雜的對象。 結構模式 Bridge將抽象從其實現中分...
摘要:孫臏心里一萬個草泥馬在奔騰,差點沒噎死自己滾一邊去,我們這盤跟他賽馬開始,策略模式上場。在設計模式之禪中的提出通過策略枚舉和反射機制對策略模式進行改良,膜拜了但是要添加或淘汰策略,還是得去對枚舉進行修改,也不符合開閉原則。 今天給大家說說田忌賽馬的故事。如有雷同,純屬巧合!話說在戰國時期,群雄割據,硝煙四起,茶余飯后還是少不了娛樂活動的,其中賽馬是最火爆的。一天,孫臏看到田忌像個死雞似...
閱讀 1364·2019-08-30 15:44
閱讀 2108·2019-08-30 11:04
閱讀 528·2019-08-29 15:17
閱讀 2548·2019-08-26 12:12
閱讀 3138·2019-08-23 18:09
閱讀 927·2019-08-23 15:37
閱讀 1529·2019-08-23 14:43
閱讀 2931·2019-08-23 13:13