1、原型对象也是普通的对象,是对象一个自带隐式的 __proto__ 属性,原型也有可能有自己的原型,如果一个原型对象的原型不为 null 的话,我们就称之为原型链
创新互联公司从2013年成立,是专业互联网技术服务公司,拥有项目网站设计制作、成都网站建设网站策划,项目实施与项目整合能力。我们以让每一个梦想脱颖而出为使命,1280元塔什库尔干塔吉克做网站,已为上家服务,为塔什库尔干塔吉克各地企业和个人服务,联系电话:18980820575
2、 原型链是由一些用来继承和共享属性的对象组成的(有限的)对象链
是这样的,在图中,SubType指的是一个构造函数,每个构造函数都有一个原型属性prototype,默认指向他的原型对象:SubType Prototype。
instance是由构造函数SubType构建的一个实例对象,实例对象继承了构造函数原型的方法和属性,同时实例和原型之间的联系就是通过某个属性联系的,在图中就表现为[[Prototype]],这个属性怎么表示不重要,重要的是你知道他的存在,并且通过他实例才能和原型联系起来,构造函数只是一个表现形式,原型对象才是真正给实例继承的。
在图中instance的[[Prototype]]和SubType的 prototype指向的是同一个原型对象。
你在chrome中可以通过:
console.log(SubType.prototype);
console.log(instance.__proto__);
来看他们的输出:
都是指向SuperType{}原型对象。
所以说[[Prototype]]只是一个表示符号,表示实例指向原型对象的一种关系,就像上面这种关系就用__proto__来表示了。
希望能帮到你,采纳我把,(*^__^*) 嘻嘻。
原型是JS的一个引用对象,就是说prototype本身就是一个对象,和OBJECT没什么不同
所有的属性中都会包含一个属性__proto__来指向你的原型对象
例如
function ROOT(){}
ROOT.A = 1
ROOT.prototype.B = 2;
//object对象是默认指向OBJECT直到你指定一个proto指针
//这里由于child本身是已经实例化的OBJECT,所以会复制一份指定的root的prototype指针引用到child
var child = {__proto__:ROOT.prototype}
//这里是child1原__proto__是指向空的object
//这里对child1的prototype指针进行了替换
var child1 = function (){};
child1.prototype = ROOT.prototype
//剩下的结果就不说了
var chd = new child1;
console.log(child.B)
console.log(chd.B)
//你会发现除了child无法实例化,其他的特性都继承了
console.log(chd.constructor)
console.log(chd.__proto__)
console.log(child.constructor)
console.log(child.__proto__)
所以这里面
__proto__是指向的创建者的原型对象
constructor是指向的创建者
prototype是当前对象的原型对象
实例化的对象会先从实例化对象里查找属性,如果找不到会在__proto__里面查找指向的prototype的属性
原型,prototype,应该指的是设计模式中的原型模式,我猜说JavaScript基于原型,意思是JavaScript语言在设计的时候充分贯彻了原型模式的思想
简单来讲:构造函数是制作蛋糕的机器, 那么原型就是蛋糕的模子, 生成出来对象自然就是蛋糕啦用代码实现:
// 这个函数是制作蛋糕的机器functionMakeCake(buyer){this.buyer=buyer;}// 我们选择一个9寸圆形的草莓蛋糕MakeCake.prototype={size:"9寸",shape:"圆形",taste:"草莓味 "}varstrawberryCake=newMakeCake("Jimmy");// 给jimmy做的草莓蛋糕出炉啦varstrawberryCake2=newMakeCake("Bob");// 再给Bob做一个// 我们选择一个12寸方形巧克力双层蛋糕模型MakeCake.prototype={size:"12寸",shape:"方形",taste:"巧克力",type:"双层的"}varchocolateCake=newMakeCake("Jimmy");// 给Jimmy做一个巧克力蛋糕 :)
那这个蛋糕制造机是怎么被生产出来的呢?制蛋糕的机器也是仿照一个模子通过一台机器制造机做出来的javascript内部有一个机器制造器叫做Function函数。而你可以把function CustomFunction(){...} 视为new Function(args, functionBody) 的语法糖。当你需要一台机器,你就可以使用new Function({...}),这个机器制造器Function就会按照一个默认的模子生产出一台机器。
要说明的是, 语法糖的说法并不是完全准确的,函数声明形式和new Function()不等价,new Function() 效率会低一些。
附一张原型链的图: 对象的__proto__属性指向它的原型
functionCat(name){this.name=name}varjetty=newCat()