亚洲免费在线视频-亚洲啊v-久久免费精品视频-国产精品va-看片地址-成人在线视频网

您的位置:首頁技術(shù)文章
文章詳情頁

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

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

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

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

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

場景:使用PC結(jié)構(gòu)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.

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

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

訪問者模式總結(jié):

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

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

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

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

更多關(guān)于JavaScript相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《javascript面向?qū)ο笕腴T教程》、《JavaScript錯誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》、《JavaScript遍歷算法與技巧總結(jié)》及《JavaScript數(shù)學(xué)運算用法總結(jié)》

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

標(biāo)簽: JavaScript
相關(guān)文章:
主站蜘蛛池模板: 日韩一区二区久久久久久 | 亚洲欧美中文在线观看4 | 91在线 | 亚洲 | 日韩亚洲精品不卡在线 | 国产精品日韩专区 | 久草中文在线 | 国内精品一区二区在线观看 | 日韩欧美高清在线 | 日本免费一区二区三区三州 | 看性过程三级视频在线观看 | 在线观看二区三区午夜 | 久草在线2 | 国产精品免费看久久久 | 日本一本久道 | 国产自愉自愉全免费高清 | 日本a级片免费看 | 亚洲欧美日韩综合一区久久 | 日韩三级视频 | 国产精品毛片 | 欧美精品黄页免费高清在线 | 欧美69视频在线 | 久久精品视频免费在线观看 | 日本三级香港三级少妇 | 亚洲一二区 | 国产91香蕉在线精品 | 一级毛片在线观看视频 | 香港三澳门三日本三级 | 国产高清在线看 | 特级a欧美孕妇做爰片毛片 特级a欧美做爰片毛片 | 亚洲一区二区三区四区在线观看 | 欧美一区高清 | 国产精品不卡 | 香蕉久久精品 | 日本免费视频观看在线播放 | 天堂一区二区三区精品 | 国产一区二区三区四区在线观看 | 亚欧在线一线 | 国产第一草草影院 | 国产精品久久一区二区三区 | 美女把张开腿男生猛戳免费视频 | 欧美视频一区二区在线观看 |