看到一篇寫的很是好的關於js繼承的文章,其中對構造函數、原型、實例之間的關係的描述十分透徹,故轉載做者文章以隨時學習,並供你們共同進步!html
ES5中的繼承,看圖:web
1 function Super() {} 2 3 function Sub() {} 4 Sub.prototype = new Super(); 5 Sub.prototype.constructor = Sub; 6 7 var sub = new Sub(); 8 9 Sub.prototype.constructor === Sub; // ② true 10 sub.constructor === Sub; // ④ true 11 sub.__proto__ === Sub.prototype; // ⑤ true 12 Sub.prototype.__proto__ == Super.prototype; // ⑦ true
ES5中這種最簡單的繼承,實質上就是將子類的原型設置爲父類的實例。函數
ES6中的繼承,看圖:學習
1 class Super {} 2 3 class Sub extends Super {} 4 5 var sub = new Sub(); 6 7 Sub.prototype.constructor === Sub; // ② true 8 sub.constructor === Sub; // ④ true 9 sub.__proto__ === Sub.prototype; // ⑤ true 10 Sub.__proto__ === Super; // ⑥ true 11 Sub.prototype.__proto__ === Super.prototype; // ⑦ true
ES6和ES5的繼承是如出一轍的,只是多了class
和extends
,ES6的子類和父類,子類原型和父類原型,經過__proto__
鏈接。ui
原文連接:ES5和ES6中的繼承spa
感謝做者:@KeenWonprototype