以下是程式碼
function A(){
this.a = 1;
this.b = 2;
}
A.prototype.drive = function(){
console.log('drivvvvvvvvvv');
}
//方式1
function B(){}
B.prototype = Object.create(new A()); //这里采用了new 一个实例
//方式2
function C(){
A.call(this);
}
C.prototype = Object.create(A.prototype) //这里使用的是父类的原型
請問大家以上兩種方式有什麼差別,為什麼我看mdn上採用的是第二種
过去多啦不再A梦2017-05-19 10:17:44
1的缺點:
執行了 new,相當於運行了一遍 A ,如果在 A 裡做了一些其它事情(如改變全局變數)就會有副作用。
用 A 創建的物件做原型,裡面可能會有一些冗餘的屬性。
2模擬了 new 的執行過程