JavaScript原型,原型链?有什么特点?

每个对象都会在其内部初始化一个属性,就是 prototype(原型),当我们访问一个对象属性石,如果这个对象内部不存在这个属性,那么他就会去prototype 里找这个属性,这个 prototype 又会有自己的 prototype。
于是就这样一直找下去,也就是我们常说的原型链的概念。
关系:instance.constructor.prototype = instance.__proto__
特点:
JavaScript 对象是通过引用来传递的,我们创建的每个新对象实体中并没有一份属于自己的原型副本。当我们修改原型是,与之相关的对象也会继承这一改变。
当我们需要一个属性时,JavaScript 引擎会先看当前对象中是否有这个属性,如果没有的话,就会查找它的 prototype 对象是否有这个属性,如此递推下去,一直检索到有 object 内建对象。
function Func(){
     }
Func.prototype.name = "Dehua";
Func.prototype.getInfo = function(){
     
	return this.name;
}
var person = new Func();// 现在可以参考 var person = Object.create(oldObject)
console.log(person.getInfo());//它拥有了Func的属性和方法
//输出为"Dehua"
console.log(Func.prototype);
//输出为 Func{name="Dehua",getInfo=function()}

你可能感兴趣的:(JavaScript)