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

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

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

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

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

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

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

場景:使用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方法,用來觸發傳遞進來的訪問者 Computer稱為對象結構,它是一個元素的集合。parts數組用于存放元素對象,以供不同訪問者訪問。_acceptAll方法用來遍歷內部元素。 訪問者通過accept訪問元素內部,元素內部也可以通過參數調用訪問者的visit方法。這種調用機制稱為雙重分派。

訪問者模式總結:

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

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

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

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

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 精品一区二区三区免费看 | igao在线观看 | 久久久久成人网 | 成人av一区二区三区在线观看 | 91亚洲国产成人久久精品麻豆 | 日韩一区二区三区在线播放 | 久久综合激情 | 国产精品久久午夜夜伦鲁鲁 | 97精品视频 | 日韩视频免费在线观看 | 亚洲午夜精品一区二区三区 | 国产一级18片视频 | 99色在线 | 日韩精品久久久久久 | 国产成年人视频 | 日日夜夜狠狠干 | 日韩视频免费大全中文字幕 | 深夜福利免费 | 日韩欧美第一页 | 欧美极品一区 | 超碰在线成人 | 成人三级视频 | 伊人亚洲 | 日韩天天操 | 亚洲国产福利 | 亚洲成人三级 | av一二三区 | 一级片在线视频 | 韩日一区二区 | 中文字幕在线观看免费视频 | 久久久免费观看 | 国产视频一区二区在线观看 | 91精选视频 | 久草资源在线 | 亚洲国产欧美在线 | 黄色小视频免费观看 | 狠狠操网 | 国产一级在线播放 | 在线成人免费视频 | 九九视频在线 | 男人添女人囗交图 |