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

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

javascript設計模式 ? 訪問者模式原理與用法實例分析

瀏覽:3日期:2023-11-01 17:31:23

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

介紹:訪問者模式比較復雜,它包含訪問者和被訪問元素兩個主要組成部分,這些被訪問的元素通常具有不同的類型,且不同的訪問者可以對他們進行不同的訪問操作。訪問者模式的主要目的是將數(shù)據(jù)結構與數(shù)據(jù)操作相分離。

定義:提供一個作用于某對象結構中的個元素的操作表示,它使得可以再不改變各元素的類的前提下定義作用于這些元素的新操作。訪問者模式是一種對象行為型模式

場景:使用PC結構demo來解釋下訪問者模式

示例:

var Keyboard = function(){ this.accept = function(computerPartVisitor){ computerPartVisitor.visit(this); }} var Monitor = function(){ this.accept = function(computerPartVisitor){ computerPartVisitor.visit(this); }} var Mouse = function(){ this.accept = function(computerPartVisitor){ computerPartVisitor.visit(this); }} var Computer = function(){ var parts = [new Keyboard(), new Monitor(), new Mouse()]; this.accept = function(computerPartVisitor){ computerPartVisitor.visit(this); _acceptAll(computerPartVisitor); } var _acceptAll = function(computerPartVisitor){ parts.map(function(item){ item.accept(computerPartVisitor) }); }} var ComputerPartDisplayVisitor = function(){ this.visit = function(item){ if(item.constructor == Keyboard){ console.log('Displaying Keyboard.'); }else if(item.constructor == Monitor){ console.log('Displaying Monitor.'); }else if(item.constructor == Mouse){ console.log('Displaying Mouse.'); }else if(item.constructor == Computer){ console.log('Displaying Computer.'); }else{ console.log('Error'); } }} var computer = new Computer();computer.accept(new ComputerPartDisplayVisitor());// Displaying Computer.// Displaying Keyboard.// Displaying Monitor.// Displaying Mouse.

這個模式比較復雜,我們先介紹下組成:

ComputerPartDisplayVisitor稱為訪問者,它為對象結構中的每一個具體元素例如Keyboard,Mouse等聲明一個訪問操作。當訪問Keyboard時就會輸出Displaying Keyboard。 Keyboard,Monitor,Mouse稱為元素,他們包含一個accept方法,用來觸發(fā)傳遞進來的訪問者 Computer稱為對象結構,它是一個元素的集合。parts數(shù)組用于存放元素對象,以供不同訪問者訪問。_acceptAll方法用來遍歷內部元素。 訪問者通過accept訪問元素內部,元素內部也可以通過參數(shù)調用訪問者的visit方法。這種調用機制稱為雙重分派。

訪問者模式總結:

優(yōu)點:* 增加新的訪問操作便捷,只需要加一個新的訪問者類。* 將有關原色對象的訪問行為集合到一個訪問者對象中,類的職責更清晰。* 讓用戶在不修改現(xiàn)有元素層次結構的情況下,定義作用于該層次結構的操作。

缺點:* 增加新的元素類很困難,在訪問者模式下,每增加一個新的元素,對應要增加訪問者中的操作。* 破壞封裝。訪問者模式要求訪問者對象訪問并調用每一個元素對象的操作,這意味著元素必須暴露一些內部操作和內部狀態(tài)。

適用場景:* 一個對象結構包含多個類型的對象,希望對這些對象實施一些依賴其具體類型的操作。* 需要對一個對象結構中的對象進行橫多不同的并且不相關的操作,而且需要避免讓這些操作污染這些對象的類。* 對象結構中對象對應的類很少改變,但經常需要再次對象結構上定義新的操作。

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

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 在线观看欧美日韩 | 欧美成人一区二区三区片免费 | 国产福利91精品一区二区三区 | 青青草综合网 | 成人免费视频国产免费 | 五月婷婷开心 | 精品福利在线 | 午夜精品福利视频 | 天天干天天插 | 日韩精品视频一区二区三区 | 97精品超碰一区二区三区 | 一区二区视频在线播放 | 色女人影院 | 欧美啪啪网 | 精品国产区 | 亚洲综合网站 | 欧美日韩亚洲国产 | 久久久久免费 | 亚洲欧美日韩一区 | 亚洲欧美在线观看 | 中国极品少妇xxxx做受 | 日韩免费精品视频 | 日本少妇一区二区 | 日本韩国欧美中文字幕 | 在线观看视频一区二区三区 | 午夜av片 | 日韩精品视频在线播放 | 六月色婷婷 | 天堂av影院| 午夜成人影片 | 欧美精品一二三 | av观看免费| 亚洲高清在线观看 | 日韩视频免费大全中文字幕 | 国产精品伦 | www.黄色网 | 色黄视频在线观看 | 99视频精品 | 91中文在线 | 精品亚洲一区二区三区 | 久久国产精品免费视频 |