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
Для отправки комментария вам необходимо авторизоваться.