首页 > 代码库 > javascript设计模式-工厂模式
javascript设计模式-工厂模式
简单工厂模式:使用一个类来生成实例。
复杂工厂模式:使用子类来决定一个成员变量应该是哪个具体的类的实例。
简单工厂模式是由一个方法来决定到底要创建哪个类的实例, 而这些实例经常都拥有相同的接口。通过工厂,可以取得需要的实例。逻辑示意图:
下面列举了一个例子:
var Coffee = function(){ this.color="brown";};var Milk = function(){ this.color="white";};var OrangeJuice=function(){ this.color="orange";};var DrinkShop = function(){ this.sellDrink = function( type){ var drink; switch( type){ case "coffee": drink= new Coffee(); break; case "milk": drink= new Milk(); break; case "orangeJuice": default: drink= new OrangeJuice(); break; } drink.showColor=function(){ console.log("Drink color:"+drink.color); }; return drink; }};var drinkShop = new DrinkShop();drinkShop.sellDrink("milk").showColor();//Drink color:white
可以看出,简单工厂会根据需要生成实例,而这些类一般都包含有某些属性或方法。比如上例中,各种drink都有color属性。这样做的好处就是把需要创建实例的部分抽离,统一管理,对于系统的各部分职能进行划分,降低耦合度。
工厂模式的适用场景:
1.对象的构建相对复杂
2.需要依赖具体环境创建不同实例
3.处理很多具有相同属性的小对象
javascript设计模式-工厂模式
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。