电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

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

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

瀏覽:5日期: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
相關文章:
主站蜘蛛池模板: 贵州科比特-防雷公司厂家提供贵州防雷工程,防雷检测,防雷接地,防雷设备价格,防雷产品报价服务-贵州防雷检测公司 | ORP控制器_ORP电极价格-上优泰百科| 电主轴,车床电磨头,变频制动电机-博山鸿达特种电机 | 天津货架厂_穿梭车货架_重型仓储货架_阁楼货架定制-天津钢力仓储货架生产厂家_天津钢力智能仓储装备 | 好物生环保网、环保论坛 - 环保人的学习交流平台 | 成都茶楼装修公司 - 会所设计/KTV装修 - 成都朗煜装饰公司 | 北京翻译公司-专业合同翻译-医学标书翻译收费标准-慕迪灵 | 偏心半球阀-电动偏心半球阀-调流调压阀-旋球阀-上欧阀门有限公司 | 杭州用友|用友软件|用友财务软件|用友ERP系统--杭州协友软件官网 | 代理记账_免费注册公司_营业执照代办_资质代办-【乐财汇】 | 德国UST优斯特氢气检漏仪-德国舒赐乙烷检测仪-北京泽钏 | 市政路灯_厂家-淄博信达电力科技有限公司 | 蒸汽吸附分析仪-进口水分活度仪|康宝百科 | 柴油发电机组_柴油发电机_发电机组价格-江苏凯晨电力设备有限公司 | 字典-新华字典-在线字典查字-字典趣 | 垃圾压缩设备_垃圾处理设备_智能移动式垃圾压缩设备--山东明莱环保设备有限公司 | 深圳APP开发公司_软件APP定制开发/外包制作-红匣子科技 | 培训无忧网-教育培训咨询招生第三方平台| 牛奶检测仪-乳成分分析仪-北京海谊| 透平油真空滤油机-变压器油板框滤油机-滤油车-华之源过滤设备 | 字典-新华字典-在线字典查字-字典趣| 北京网络营销推广_百度SEO搜索引擎优化公司_网站排名优化_谷歌SEO - 北京卓立海创信息技术有限公司 | 纸布|钩编布|钩针布|纸草布-莱州佳源工艺纸布厂 | 安徽泰科检测科技有限公司【官方网站】| 电镀整流器_微弧氧化电源_高频电解电源_微弧氧化设备厂家_深圳开瑞节能 | 分光色差仪,测色仪,反透射灯箱,爱色丽分光光度仪,美能达色差仪维修_苏州欣美和仪器有限公司 | 河北凯普威医疗器材有限公司,高档轮椅系列,推车系列,座厕椅系列,协步椅系列,拐扙系列,卫浴系列 | 标准件-非标紧固件-不锈钢螺栓-非标不锈钢螺丝-非标螺母厂家-三角牙锁紧自攻-南京宝宇标准件有限公司 | 酒精检测棒,数显温湿度计,酒安酒精测试仪,酒精检测仪,呼气式酒精检测仪-郑州欧诺仪器有限公司 | POS机办理_个人POS机免费领取 - 银联POS机申请首页 | 汽液过滤网厂家_安平县银锐丝网有限公司| 电动手术床,医用护理床,led手术无影灯-曲阜明辉医疗设备有限公司 | 智能交通网_智能交通系统_ITS_交通监控_卫星导航_智能交通行业 | 无机纤维喷涂棉-喷涂棉施工工程-山东华泉建筑工程有限公司▲ | 包装盒厂家_纸盒印刷_礼品盒定制-济南恒印包装有限公司 | 楼承板-开闭口楼承板-无锡海逵楼承板 | 恒温恒湿箱(药品/保健品/食品/半导体/细菌)-兰贝石(北京)科技有限公司 | 台湾HIWIN上银直线模组|导轨滑块|TBI滚珠丝杆丝杠-深圳汉工 | 安平县鑫川金属丝网制品有限公司,防风抑尘网,单峰防风抑尘,不锈钢防风抑尘网,铝板防风抑尘网,镀铝锌防风抑尘网 | ASA膜,ASA共挤料,篷布色母料-青岛未来化学有限公司 | 铁艺,仿竹,竹节,护栏,围栏,篱笆,栅栏,栏杆,护栏网,网围栏,厂家 - 河北稳重金属丝网制品有限公司 山东太阳能路灯厂家-庭院灯生产厂家-济南晟启灯饰有限公司 |