av一区二区在线观看_亚洲男人的天堂网站_日韩亚洲视频_在线成人免费_欧美日韩精品免费观看视频_久草视

您的位置:首頁技術文章
文章詳情頁

javascript設計模式 ? 模板方法模式原理與用法實例分析

瀏覽:3日期:2023-11-02 13:37:17

本文實例講述了javascript設計模式 ? 模板方法模式原理與用法。分享給大家供大家參考,具體如下:

介紹:模板方法模式是結構最簡單的行為型設計模式,在其結構中只存在父類與子類之間的繼承關系。使用模板方法模式,可以將一些復雜流程的實現步驟封裝在一系列基本方法中。

定義:定義一個操作中算法的框架,而將一些步驟延遲到子類中,模板方法使得子類可以不改變一個算法的結構即可重定義該算法的某些特定步驟。模板方法是一種類行為型模式。

場景:我們設計一個游戲機,用來運行不同的游戲,

示例:

var Game = function(){ this.play = function(){ this.initialize(); this.startPlay(); this.endPlay(); this.uninstall(); } this.uninstall = function(){ console.log(’uninstall Game’) }} var CrossFire = function(){ this.initialize = function(){ console.log(’CrossFire initialize’) } this.startPlay = function(){ console.log(’CrossFire startPlay’) } this.endPlay = function(){ console.log(’CrossFire endPlay’) }}CrossFire.prototype = new Game(); var LeagueofLegends = function(){ this.initialize = function(){ console.log(’LeagueofLegends initialize’) } this.startPlay = function(){ console.log(’LeagueofLegends startPlay’) } this.endPlay = function(){ console.log(’LeagueofLegends endPlay’) }}LeagueofLegends.prototype = new Game(); var cf = new CrossFire();cf.play();// CrossFire initialize// CrossFire startPlay// CrossFire endPlay// uninstall Gamevar lol = new LeagueofLegends();lol.play();// LeagueofLegends initialize// LeagueofLegends startPlay// LeagueofLegends endPlay// uninstall Game

在這個例子里,Game稱為抽象類,抽象類內部定義了一個模板方法play,play的內部定義了算法的架構,算法的執行順序,只有子類將步驟補齊后才能執行模板方法。LeagueofLegends,CrossFire這兩個類稱為子類,繼承自Game,他們的任務是實現模板方法中的步驟。initialize,startPlay,endPlay,uninstall稱為基本方法,用來具體實現每個步驟

模板方法模式總結:

優點:* 模板方法模式是一種代碼復用技術,將公共行為放在父類中,而通過其子類來實現不同的行為,他鼓勵恰當使用繼承來實現代碼復用。* 模板方法可以實現一種反向控制結構,通過子類覆蓋父類的方法來決定某一步驟是否執行。

缺點:* 需要為每一個基本方法的不同實現提供一個子類,如果父類中可變的基本方法太多,將會導致類的個數增加,系統更加龐大。

適用場景:* 對一些復雜的算法進行分割,將其中固定不變的布馮設計為模板方法和父類基本方法,改變的細節由子類實現。* 各子類的公共行為應當被提取出來并集中帶一個父類中,利于代碼復用。* 需要子類決定父類的某個步驟是否執行,實現子類對父類的反向控制。

感興趣的朋友可以使用在線HTML/CSS/JavaScript代碼運行工具:http://tools.jb51.net/code/HtmlJsRun測試上述代碼運行效果。

更多關于JavaScript相關內容感興趣的讀者可查看本站專題:《javascript面向對象入門教程》、《JavaScript錯誤與調試技巧總結》、《JavaScript數據結構與算法技巧總結》、《JavaScript遍歷算法與技巧總結》及《JavaScript數學運算用法總結》

希望本文所述對大家JavaScript程序設計有所幫助。

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 91精品久久久久久久久 | 欧美一区不卡 | 一本一道久久a久久精品蜜桃 | 欧美日韩国产在线观看 | 一级免费黄色片 | 91在线视频 | 在线看片a| 无遮挡在线观看 | 黄色片视频免费 | 涩涩999| 老司机免费福利视频 | 成人一级黄色片 | 久久精品av| 人人看人人草 | 日韩精品第一页 | 日韩在线不卡视频 | 黄色大片av | 中文字幕第一区 | 国产免费一区二区三区最新不卡 | 亚洲伦理在线观看 | 欧美视频在线一区 | 97久久久久 | 亚洲无人区一线二线三线 | 久久久影院| 五月激情网站 | 日韩在线免费观看视频 | 波多野结衣视频在线播放 | 久久国产小视频 | 99久久婷婷国产综合精品草原 | 久久香蕉精品 | 国产欧美久久久 | 精品免费国产一区二区三区四区 | 国产99页| 中文字字幕 | 亚洲视频免费 | 国产成人免费 | 欧美又大又硬又粗bbbbb | 欧美日本在线观看 | 四虎成人精品 | 青青艹在线视频 | www.天天干|