工厂方法模式

// 工厂方法模式
// 案例:投放培训广告,有java用绿色字体、php用黄色字体红色背景

// 工厂方法模式
// 案例:投放培训广告,有java用绿色字体、php用黄色字体红色背景

// 创建JAVA学科类
var Java = function (content) {
	// 将内容保存在content里面以日后备用
	this.content = content;
	// 创建对象时,通过闭包直接执行,将内容按需求的样式插入到页面内
	(function(content){
		var div = document.createElement('div');
		div.innerHTML = content;
		div.style.color = 'green';
		document.getElementById('container').appendChild(div);
	})(content);
}

// 创建PHP学科类
var Php = function (content) {
	// 将内容保存在content里面以日后备用
	this.content = content;
	// 创建对象时,通过闭包直接执行,将内容按需求的样式插入到页面内
	(function(content){
		var div = document.createElement('div');
		div.innerHTML = content;
		div.style.color = 'yellow';
		div.style.background = 'red';
		document.getElementById('container').appendChild(div);
	})(content);
} 

// 学科类工厂
function JobFactory(type,content){
	switch(type){
		case 'java':
			return new Java(content);
		case 'php':
			return new Php(content);
	}
}

// 调用 两个学科
JobFactory('java','Java哪家强');
JobFactory('php','php');

// 问题:
// 如果还需要添加UI学科,js学科的话,就需要修改工厂以及新增学科类。如果经常添加就比较麻烦
// 解决办法:工厂方法模式
// 将工厂方法看作是一个实例化对象的工厂类,安全起见,我们采用安全模式类,而我们将创建对象的基类放在工厂方法类的原型中即可。
// 如果后续需要添加学科,只需在工厂原型中添加对象基类

// 问题:
// 如果还需要添加UI学科,js学科的话,就需要修改工厂以及新增学科类。如果经常添加就比较麻烦
// 解决办法:工厂方法模式
// 将工厂方法看作是一个实例化对象的工厂类,安全起见,我们采用安全模式类,而我们将创建对象的基类放在工厂方法类的原型中即可。
// 如果后续需要添加学科,只需在工厂原型中添加对象基类
var Factory = function(type,content){
	if (this instanceof Factory) {
		// 判断是否是Factory的子类  是否有new 是则返回工厂原型中的对象基类实例
		var s = new this[type](content);
		return s;
	}else{
		return new Factory(type, content);//没有new  重新返回new
	}
}

// 工厂原型中设置创建所有类型数据对象的基类
Factory.prototype = {
	Java:function (content) {
		// 将内容保存在content里面以日后备用
		this.content = content;
		// 创建对象时,通过闭包直接执行,将内容按需求的样式插入到页面内
		(function(content){
			var div = document.createElement('div');
			div.innerHTML = content;
			div.style.color = 'green';
			document.getElementById('container').appendChild(div);
		})(content);
	},
	Php:function (content) {
		// 将内容保存在content里面以日后备用
		this.content = content;
		// 创建对象时,通过闭包直接执行,将内容按需求的样式插入到页面内
		(function(content){
			var div = document.createElement('div');
			div.innerHTML = content;
			div.style.color = 'yellow';
			div.style.background = 'red';
			document.getElementById('container').appendChild(div);
		})(content);
	},
	UI: function (content) {
		// 将内容保存在content里面以日后备用
		this.content = content;
		// 创建对象时,通过闭包直接执行,将内容按需求的样式插入到页面内
		(function(content){
			var div = document.createElement('div');
			div.innerHTML = content;
			div.style.border = '1px solid red';
			document.getElementById('container').appendChild(div);
		})(content);
	}
}


var data = [
	{type:'Java',content:'js哪家强'},
	{type:'Php',content:'php哪家强'},
	{type:'UI',content:'java哪家强'}
]
// 多个遍历调用
for (var i = 0; i < data.length; i++) {
	Factory(data[i].type,data[i].content);
}

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值