Leave a Comment
            Наследование в Javascript
Table of Contents
Рекомендация ECMAScript5
Минус — вызывается конструктор родителя раньше времени.
https://jsbin.com/zoxude/1/edit?js,output
| 
					 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26  | 
						var Animal = function () {   this.type = 'animal'; }; Animal.prototype.getType = function () {   return this.type; }; Animal.prototype.getName = function () {   return 'My name is ' + this.name; }; var Turtle = function () { }; Turtle.prototype = new Animal(); var NinjaTurtle = function (name) {   this.name = name; }; NinjaTurtle.prototype = new Turtle(); var donatello = new NinjaTurtle('Donatello'); console.log(donatello.getType()); console.log(donatello.type); console.log(donatello.name); console.log(donatello.getName());  | 
					
Через временный конструктор
https://jsbin.com/desuli/1/edit?js,output
Родительский конструктор не вызывается вообще.
При этом наследуется только то, что есть в прототипах.
По-хорошему нужно в конструкторе вызвать родительский конструктор.
| 
					 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35  | 
						function extend(child, parent) {   var f = function () {};   f.prototype = parent.prototype;   child.prototype = new f();   child.prototype.constructor = child; } var Animal = function () {   this.selfType = 'self_animal'; }; Animal.prototype.type = 'animal'; Animal.prototype.getType = function () {   return this.type; }; Animal.prototype.getName = function () {   return 'My name is ' + this.name; }; var Turtle = function () { }; extend(Turtle, Animal); var NinjaTurtle = function (name) {   this.name = name; }; extend(NinjaTurtle, Turtle); var donatello = new NinjaTurtle('Donatello'); console.log(donatello.getType()); console.log(donatello.type); console.log(donatello.selfType); console.log(donatello.name); console.log(donatello.getName());  | 
					
ES2015
| 
					 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32  | 
						class Animal {   constructor() {     this.type = 'animal';   }   getType() {     return this.type;   }   getName() {     return this.name;   } } class Turtle extends Animal {   constructor() {     super();     this.type = 'animal';   } } class NinjaTurtle extends Turtle {   constructor(name) {     super();     this.name = name;   } } let donatello = new NinjaTurtle('Donatello'); console.log(donatello.getType()); console.log(donatello.type); console.log(donatello.name); console.log(donatello.getName());  | 
					
Результат компиляции Babel-ом:
| 
					 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68  | 
						'use strict'; var _createClass = function () { function defineProperties(target, props) { for (var i = 0; i < props.length; i++) { var descriptor = props[i]; descriptor.enumerable = descriptor.enumerable || false; descriptor.configurable = true; if ("value" in descriptor) descriptor.writable = true; Object.defineProperty(target, descriptor.key, descriptor); } } return function (Constructor, protoProps, staticProps) { if (protoProps) defineProperties(Constructor.prototype, protoProps); if (staticProps) defineProperties(Constructor, staticProps); return Constructor; }; }(); function _possibleConstructorReturn(self, call) { if (!self) { throw new ReferenceError("this hasn't been initialised - super() hasn't been called"); } return call && (typeof call === "object" || typeof call === "function") ? call : self; } function _inherits(subClass, superClass) { if (typeof superClass !== "function" && superClass !== null) { throw new TypeError("Super expression must either be null or a function, not " + typeof superClass); } subClass.prototype = Object.create(superClass && superClass.prototype, { constructor: { value: subClass, enumerable: false, writable: true, configurable: true } }); if (superClass) Object.setPrototypeOf ? Object.setPrototypeOf(subClass, superClass) : subClass.__proto__ = superClass; } function _classCallCheck(instance, Constructor) { if (!(instance instanceof Constructor)) { throw new TypeError("Cannot call a class as a function"); } } var Animal = function () {   function Animal() {     _classCallCheck(this, Animal);     this.type = 'animal';   }   _createClass(Animal, [{     key: 'getType',     value: function getType() {       return this.type;     }   }, {     key: 'getName',     value: function getName() {       return this.name;     }   }]);   return Animal; }(); var Turtle = function (_Animal) {   _inherits(Turtle, _Animal);   function Turtle() {     _classCallCheck(this, Turtle);     var _this = _possibleConstructorReturn(this, Object.getPrototypeOf(Turtle).call(this));     _this.type = 'animal';     return _this;   }   return Turtle; }(Animal); var NinjaTurtle = function (_Turtle) {   _inherits(NinjaTurtle, _Turtle);   function NinjaTurtle(name) {     _classCallCheck(this, NinjaTurtle);     var _this2 = _possibleConstructorReturn(this, Object.getPrototypeOf(NinjaTurtle).call(this));     _this2.name = name;     return _this2;   }   return NinjaTurtle; }(Turtle); var donatello = new NinjaTurtle('Donatello'); console.log(donatello.getType()); console.log(donatello.type); console.log(donatello.name); console.log(donatello.getName());  | 
					
Similar Posts
LEAVE A COMMENT
Для отправки комментария вам необходимо авторизоваться.