看别人的代码:
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
现在都是各自本身的属性,修改就不会相互影响了。
首先你要知道构造函数过程中发生了什么,简单的说分四步
1.创建一个新对象
2.将构造函数的作用域赋给新对象(也就是this指向了新对象)
3.执行构造函数中的代码
4.返回新对象
所以 new SubClass()的过程为
1.生成一个新对象//先假设为obj
2.this指向了obj
3.执行代码
4.返回新对象obj
①
构造函数你new一个实例对象,其实就是复制了一次构造函数,同时实例根据设置的访问等级可以访问其内部的属性和方法,该对象是一个空对象,它的原型指向构造函数的prototype属性,而并不是构造函数本身,所以你对新生成的实例对象的修改是并不能影响到它的构造函数的内容,只能修改其实例自身。
谢谢大家,大家都说得对,不过只能采纳一个答案,我就采纳第一个回答的吧
另外我总结了一下:
call直接使用超类的构造函数,将超类的构造函数生成的属性和方法放到子类,并且传入了当前的 this来运行,那么就相当于以子类的身份执行超类的构造函数,那么自然超类的构造函数的属性和方法会继承到子类里
因为每次 new 子类的时候,都会生成独立的子类实例对象,所以相互独立
再次谢谢.