亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

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

javascript設計模式 ? 工廠模式原理與應用實例分析

瀏覽:4日期:2023-11-05 08:02:05

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

介紹:前面我們介紹了簡單工廠模式,簡單工廠模式存在一個嚴重的問題:當需要擴展時必定要修改工廠類的源代碼。我們雖然在第二個demo中做了一些優化,但是我們需在使用時明確指定執行方法的名字,這無疑提高了使用成本。那如何實現增加新產品而不影響已有代碼?工廠模式應運而生。

定義:定義一個用于創建對象的接口,讓子類決定將哪一個類實例化。工廠模式讓一個類的實例化延遲到其子類。工廠模式又稱為工廠方法模式,又可稱為虛擬構造器模式或多態工廠模式。工廠模式是一種類創建型模式。

場景:還是基于簡單工廠模式的場景,我們試著用工廠模式解決彈窗類的問題。

示例:

var Dialog = function(){ this.show = function(){ console.log(this.name + ’ is show -> ’ + this.element); }}; Dialog.createNotice = function(){ var _dialog = new Dialog(); _dialog.element = ’<div>notice</div>’; _dialog.name = ’notice’; return _dialog;}; Dialog.createToast = function(){ var _dialog = new Dialog(); _dialog.element = ’<div>toast</div>’; _dialog.name = ’toast’; return _dialog;}; Dialog.createWarnin = function(){ var _dialog = new Dialog(); _dialog.element = ’<div>warnin</div>’; _dialog.name = ’warnin’; return _dialog;}; var Factory = {}; Factory.NoticeFactory = function(){ return Dialog.createNotice();} Factory.ToastFactory = function(){ return Dialog.createToast();} Factory.WarninFactory = function(){ return Dialog.createWarnin();} var notice = Factory.NoticeFactory();var toast = Factory.ToastFactory();var warnin = Factory.WarninFactory();notice.show(); //notice is show -> <div>notice</div>toast.show(); //toast is show -> <div>toast</div>warnin.show(); //warnin is show -> <div>warnin</div>

對比簡單工廠模式,工廠模式解決了什么問題呢?

最主要的就是將簡單工廠模式的factory方法進行拆分

交由其子類也就是createToast方法實現

而將所有工廠入口拆成獨立工廠類,之前的簡單工廠模式在新增時需要修改工廠類,違反了開關原則

工廠模式保證新增時只做添加不做修改

項目足夠大時,你可以將Factory和Dialog的子類拆成文件進行管理

在寫工廠模式的這段時間,查了一些資料,發現每個人都有自己的理解

看到的一些工廠模式的demo更像是我們前面介紹簡單工廠模式,為什么呢?

我們的demo參考的是java的書籍,這里面包含了抽象類這個概念,在前端只能靠自己的理解去描述

所以我們盡力通過一些差別來具體的介紹每一種模式

這里面的例子可能不是特別嚴謹,我后面會慢慢優化,寫的詳細一些只有一個目的

當有一天有人問我簡單工廠模式和工廠模式的區別在哪,我希望我能給出一個我的理解

工廠模式總結:

優點:* 增加新產品時,無需修改已存在的代碼* 只暴露工廠類,對具體實現封裝在內部,使用時無需關注內部使用

缺點:* 新增時還是需要新增具體實現以及提供具體的工廠類,一定程度增加了系統復雜度,會帶來一些額外開銷* 每個工廠只生產一種產品,會導致存在大量的工廠類,大大增加了系統的維護成本和運行開銷

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

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

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

標簽: JavaScript
相關文章:
主站蜘蛛池模板: 九九在线免费观看视频 | 亚洲中国日本韩国美国毛片 | 精品专区 | 日韩一级欧美一级毛片在线 | 黑人狂躁日本妞中文字幕 | 一级黄色日本 | 日韩欧美中| 国产精品7m凸凹视频分类大全 | 黄色在线免费观看视频 | 亚洲人成亚洲人成在线观看 | 黄色一级片在线 | 国产成人福利在线 | 色综合久久婷婷天天 | 乡村乱妇一级毛片 | 永久精品免费影院在线观看网站 | 中国在线观看免费的www | 亚洲精品一区二区三区中文字幕 | 天天综合色天天桴色 | 伊人亚洲影院 | 狠狠综合久久久久综合小说网 | 久久在线视频播放 | 精品日韩二区三区精品视频 | 亚洲www.| 亚洲黄色在线观看 | 国产成人黄色 | 国内视频一区二区 | 免费观看日本a毛片 | 亚洲视频91 | 亚洲欧美日韩在线中文一 | 亚洲欧洲日产国码天堂 | 国产v在线在线观看羞羞答答 | 亚州一级 | 成人看片黄a免费看视频 | 国产成人精品免费视频软件 | 国产一区二区三区露脸 | 永久在线观看视频 | 国产精品a v 免费视频 | 亚洲欧美一区二区三区国产精品 | 日韩专区中文字幕 | 国产亚洲精品精品国产亚洲综合 | 亚洲精品视频在线 |