DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> javascript抽象工廠模式詳細說明
javascript抽象工廠模式詳細說明
編輯:關於JavaScript     

抽象工廠模式說明

1. 工廠方法模式的問題: 在工廠方法模式裡,創建類都需要通過 工廠類,如果要擴展程序,就必須修改工廠類,這違背了閉包原則,對擴展開放,對修改關閉;對於設計有一定的問題。
 
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# 使用的工廠模式,都用到接口,接口是對外向各種用戶暴露的可用方法,說明這個功能應用有些什麼的方法應用,用戶應該怎麼用這個接口。對象以類的形式表現出來,代表現實世界中的某種抽象,也許場景會有很多類似的應用,比如上面的 郵件發送,短信發送,再比如商場中的各種促銷手段,以及動物世界中的各種飛禽走獸等..

如果我們不以接口形式提供用戶使用,勢必提供暴露真實的功能類對象給用戶,用戶可以隨意對類對象進行修改跟擴展,這是不允許的。

工廠方法模式 跟 抽象工廠模式可以很好的解決這樣的問題,用戶只能使用接口調用工廠類,來進行規定的操作;抽象工廠模式更進一步使用擴展功能變得容易,功能類跟工廠類都在實現相應的接口上實現各自類級別的擴展,不會涉及修改到其他的類或方法;

XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved