[設計模式] javascript 之 抽象原廠模式
抽象原廠模式說明 1. Factory 方法模式的問題: 在Factory 方法模式裡,建立類都需要通過 工廠類,如果要擴充程式,就必須修改工廠類,這違背了閉包原則,對擴充開放,對修改關閉;對於設計有一定的問題。 2. 如何解決:就要用到抽象原廠模式,就是對功能類單獨建立工廠類,這樣就不必修改之前的代碼,又擴充了功能。 3. 原廠模式其實就是對 實現同一介面的 實作類別 的 統一 工廠方式建立調用,但 javascript 沒有介面這號東西,所以就去掉這一層 實現,但位功能類的成員及方法都應當一樣; 抽象工廠源碼例子 1. 郵件發送類: 複製代碼function MailSender() { this.to = ''; this.title = ''; this.content = '';} MailSender.prototype.send = function() { //send body}複製代碼2. 簡訊發送類: 複製代碼function SmsSender() { this.to = ''; this.title = ''; this.content = '';} SmsSender.prototype.send = function() { //send body}複製代碼3. 這裡本來是建立工廠介面類,這裡就去掉了; 直接建立各功能類工廠; 1>. 郵件工廠類: function MailFactory() { }MailFactory.prototype.produce = function() { return new MailSender();}2>. 簡訊工廠類: function SmsFactory() { }SmsFactory.prototype.produce = function() { return new SmsSender();}4. 使用方法: var factory = new MailFactory();var sender = factory.produce();sender.to = 'toname#mail.com';sender.title = '抽象原廠模式';sender.content = '發送內容';sender.send();其他說明 在物件導向語言如 java,.net C# 使用的原廠模式,都用到介面,介面是對外向各種使用者暴露的可用方法,說明這個功能應用有些什麼的方法應用,使用者應該怎麼用這個介面。對象以類的形式表現出來,代表現實世界中的某種抽象,也許情境會有很多類似的應用,比如上面的 郵件發送,簡訊發送,再比如商場中的各種促銷手段,以及動物世界中的各種飛禽走獸等.. 如果我們不以介面形式提供使用者使用,勢必提供暴露真實的功能類對象給使用者,使用者可以隨意對類對象進行修改跟擴充,這是不允許的。 Factory 方法模式 跟 抽象原廠模式可以很好的解決這樣的問題,使用者只能使用介面調用工廠類,來進行規定的操作;抽象原廠模式更進一步使用擴充功能變得容易,功能類跟工廠類都在實現相應的介面上實現各自類層級的擴充,不會涉及修改到其他的類或方法;