午夜剧场伦理_日本一道高清_国产又黄又硬_91黄色网战_女同久久另类69精品国产_妹妹的朋友在线

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

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

瀏覽:26日期: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
相關文章:
主站蜘蛛池模板: 日韩和的一区二区 | 五月天婷婷激情 | 亚洲视频在线观看网站 | 激情开心成人网 | 欧美日本综合 | 亚洲黄色a| 四虎影院永久在线 | 伊人精品影院 | av亚洲精品 | 欧美性猛交xxxx免费看 | 99自拍视频在线观看 | 噜噜噜视频 | 50一60岁老妇女毛片 | 欧美手机在线 | 欧美精品在线视频 | 成人av免费看 | 奇米影视中文字幕 | 欧美一区二区三区激情视频 | 欧美日本在线 | 毛片小视频 | 亚洲不卡一 | 一级黄色片欧美 | 免费中文字幕 | 欧美日韩a v | 男人的伸进里面免费网站 | 久久一区| 国产成人精品综合在线观看 | 日韩一区二区在线播放 | 亚洲日日夜夜 | 日本综合色 | 亚洲成人精品一区二区 | 亚洲国产精品免费在线观看 | 欧美a视频 | 国产精品88av| 国产福利第一页 | 久久久久无码国产精品一区 | 成人av免费看 | 国产激情在线播放 | 亚洲天堂网站 | 亚洲精品乱码久久久久久日本蜜臀 | 日本天天色 |