工厂方法模式

// 工厂方法模式
// 案例:投放培训广告,有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);
}

 

【源码免费下载链接】:https://renmaiwang.cn/s/fb7fi UPF流程详解:Unified Power Format(UPF)是一种规范化的文件格式,用于约束芯片中的电源域设计。在RTL设计到GDSII生成的全过程中,各EDA工具均可读取UPF文件完成相关处理工作。UPF的诞生旨在应对低功耗设计挑战,提供一种通用的标准来描述芯片中的电源区域结构。从历史发展来看,UPF经历了多个版本的演进。2007年2月22日,Synopsys、Mentor Graphics和Magma Design Automation公司联合发布UPF 1.0标准;随后,Cadence设计系统公司开发的通用功率格式(CPF-Common Power Format)向行业开放。2009年3月27日,IEEE及多家合作伙伴共同推出了UPF 2.0标准;2013年5月29日,该标准被更新为UPF 2.1;2015年12月5日,则升级至UPF 3.0。在培训课程中,UPF 1.0和UPF 2.0均有所涉及,但UPF 2.0已取代其他版本成为主流选择。要采用UPF 2.0标准,则需要更新部分EDA工具以支持其功能。UPF涵盖了多个低功耗单元,包括Level-shifter、Isolation Cell、Power Gating cells以及Always-on单元。其中,Level-shifter用于实现不同电压域之间的信号电平转换;Isolation Cell用于电源关断技术,在电源关闭时输出信号处于不确定状态,从而导致负载单元产生内部电流,造成不必要的功耗;Power Gating cells则通过选择性地开启或关闭VDD与VSS的连接来实现电源管理;而Retention-Register则负责在电源关断模块要求下锁存或恢复数据。使用UPF时,需确保选用支持其功能的工具。例如,Synop
解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店升级到最新版本客户端后再登录" 解决个别微信版本,登录提示:"当前客户端版本过低,请前往应用商店
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值