這篇文章將為大家詳細講解有關(guān)web前端中訪問者模式的示例分析,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。
成都創(chuàng)新互聯(lián)主要從事網(wǎng)站設(shè)計、成都網(wǎng)站建設(shè)、網(wǎng)頁設(shè)計、企業(yè)做網(wǎng)站、公司建網(wǎng)站等業(yè)務(wù)。立足成都服務(wù)黟縣,十多年網(wǎng)站建設(shè)經(jīng)驗,價格優(yōu)惠、服務(wù)專業(yè),歡迎來電咨詢建站服務(wù):18980820575
訪問者模式 是一種將算法與對象結(jié)構(gòu)分離的設(shè)計模式,通俗點講就是:訪問者模式讓我們能夠在不改變一個對象結(jié)構(gòu)的前提下能夠給該對象增加新的邏輯,新增的邏輯保存在一個獨立的訪問者對象中。訪問者模式常用于拓展一些第三方的庫和工具。
// 訪問者 class Visitor { constructor() {} visitConcreteElement(ConcreteElement) { ConcreteElement.operation() }}// 元素類 class ConcreteElement{ constructor() { } operation() { console.log("ConcreteElement.operation invoked"); } accept(visitor) { visitor.visitConcreteElement(this) }}// clientlet visitor = new Visitor()let element = new ConcreteElement()elementA.accept(visitor)
訪問者模式的實現(xiàn)有以下幾個要素:
Visitor Object:訪問者對象,擁有一個visit()
方法
Receiving Object:接收對象,擁有一個accept()
方法
visit(receivingObj):用于Visitor接收一個Receiving Object
accept(visitor):用于Receving Object
接收一個Visitor,并通過調(diào)用Visitor
的 visit()
為其提供獲取Receiving Object
數(shù)據(jù)的能力
簡單的代碼實現(xiàn)如下:
Receiving Object:function Employee(name, salary) { this.name = name; this.salary = salary;}Employee.prototype = { getSalary: function () { return this.salary; }, setSalary: function (salary) { this.salary = salary; }, accept: function (visitor) { visitor.visit(this); }}Visitor Object:function Visitor() { }Visitor.prototype = { visit: function (employee) { employee.setSalary(employee.getSalary() * 2); }}
驗證一下:
const employee = new Employee('bruce', 1000); const visitor = new Visitor(); employee.accept(visitor);console.log(employee.getSalary()); //輸出:2000
場景
對象結(jié)構(gòu)中對象對應(yīng)的類很少改變,但經(jīng)常需要在此對象結(jié)構(gòu)上定義新的操作
需要對一個對象結(jié)構(gòu)中的對象進行很多不同的并且不相關(guān)的操作,而需要避免讓這些操作"污染"這些對象的類,也不希望在增加新操作時修改這些類。
優(yōu)點
符合單一職責(zé)原則
優(yōu)秀的擴展性
靈活性
缺點
具體元素對訪問者公布細節(jié),違反了迪米特原則
違反了依賴倒置原則,依賴了具體類,沒有依賴抽象。
具體元素變更比較困難
關(guān)于“web前端中訪問者模式的示例分析”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,使各位可以學(xué)到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。
網(wǎng)頁標(biāo)題:web前端中訪問者模式的示例分析
網(wǎng)站鏈接:http://jinyejixie.com/article20/gcecco.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站維護、域名注冊、標(biāo)簽優(yōu)化、建站公司、微信小程序、App設(shè)計
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)