javascript---原型模式

这篇博客探讨了JavaScript中的原型模式,介绍了如何通过Object.create方法实现对象的克隆和原型继承,从而提高代码效率。文章提到了Object.create带来的性能提升,包括代码简洁性,但也指出其在某些情况下可能存在微小的性能损失。示例代码展示了如何使用clone函数以及newP函数创建新对象,并调用相关方法。
摘要由CSDN通过智能技术生成

原型模式

创建一个共享的原型
并通过拷贝这些原型创建新的对象
用于创建重复的对象
也就是创建一个对象作为另一个对象的prototype属性值,我们也可以通过Object.create(prototype, optionalDescriptorObjects)来实现原型继承。
Object.create() 方法会使用指定的原型对象及其属性去创建一个新的对象。
------ 带来性能上的提升【
1、代码简洁
2、Object.create方法是处理计算机的二进制,性能微低

原型模式1
原型模式2
ES5提供了原生的克隆方法:Object.create,不支持这个方法的浏览器可以使用如下代码:

function clone(obj){
    function F(){};
    F.prototype = obj;
    return new F();
}

var ektype = clone(noumenon);
	//---------------------------------------------------
var car ={
	name:'比例'
}
var newPrototype = Object.create(car);
newPrototype.name="你好";
// console.log(car)
console.log(newPrototype)
//------------------------------------------------------
var new_prototype = {
	init:function(tempModel){
		this.model = tempModel;
	},
	getModel:function(){
		console.log(this.model);
	}
}
function newP(model){
	function NewPF(){};
	NewPF.prototype = new_prototype;
	var newpf = new NewPF();
	newpf.init(model); 
	return newpf
} 
var f_new_prototype = newP('你好啊,傻傻');
f_new_prototype.getModel()

打印结果

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值