看别人的代码:
function SuperClass() {
this.name = "women";
this.bra = ["a", "b"];
}
function SubClass() {
this.subname = "your sister";
//将SuperClass的作用域赋予当前构造函数,实现继承
SuperClass.call(this);
}
var sub1 = new SubClass();
sub1.bra.push("c");
console.log(sub1.bra);//["a","b","c"]
var sub2 = new SubClass();
console.log(sub2.bra);//["a","b"]
他的解释如下:
SuperClass.call(this);这一句话的意思是在SubClass的实例(上下文)环境中调用了SuperClass构造函数的初始化工作,这样每一个实例就会有自己的一份bra属性的副本了,互不产生影响了。
我有疑问的地方是:
为什么用 call 了就能每个实例都有一个副本?我查了一下 call 的作用也只是改变了 this 或者以其他对象身份运行某些方法,但是没有提到这样能够创建副本
谢谢
来看看创造实例的时候发生了什么。
对于sub2的创造是一样的。
中间相当于
sub2.bra=["a","b"]
而不是之前的
sub1.bra
指向XXX.prototype.bra
sub2.bra
也指向XXX.prototype.bra
现在都是各自本身的属性,修改就不会相互影响了。