1 回答
TA贡献1859条经验 获得超6个赞
每个函数就是一个对象(Function),函数对象都有一个子对象 prototype对象,类是以函数的形式来定义的。prototype表示该函数的原型,也表示一个类的成员的集合。
也就是说prototype 是原型,是Function对象才有的属性,原型主要是用来实现继承,从而用js 进行面向对象编程
如 Foo 是一个Function对象,是有prototype属性的 ,它指向一个Boo 的实例对象
而p 是一个 Foo 的实例对象,不是一个Function 对象,没有prototype 属性,但是p有一个私有属性__proto__ 这个属性,一般不直接访问的,事实上这个属性就是 Foo.prototype
在chrome控制台中测试
console.log(p.__proto__ == Foo.prototype)
VM952:2 true
console.log(p.__proto__ === Foo.prototype)
VM956:2 true
上述测试都输出true,说明他们确实是同一个东西js的继承是通过原型继承的,有个原型链的概念,而原型链就是通过__proto__属性实现的
function Boo() {this.x="test in Boo";}
function Foo() {this.y = "test in Foo"}
Foo.prototype = new Boo;
p=new Foo;
console.log(p.y);//test in Foo
console.log(p.x);//test in Boo
Foo 中并没有属性x,当p找不到属性x时,就到p.__proto__属性(指向原型)中找,原型中是有x属性的,于是输出x的值如果不考虑内部实现,就好像属性x是从Boo中继承的一样
console.log(p.__proto__); 输出 Boo{}表示一个空的Boo对象(通过 new Boo 创建的 )
p.__proto__.p.__proto__这个会报错,因为p.__proto__中没有名为p的属性
function Foo() {}
p=new Foo;
console.log(p.__proto__);
因为没有改变Foo.prototype 的属性,所以仍然指向它自己(Foo)
而 p.__proto__ 就是 Foo.prototype 所有输出Foo{} 表示一个空的Foo对象。
添加回答
举报