basarat.gitbooks.io/typescript/content/docs/classes-emit.html

аю сМашинопись и пытается понять скомпилированный код Javascript, сгенерированный компилятором

Машинописный код:

class A { }
class B extends A { }

Сгенерированный код Javascript:

var __extends = (this && this.__extends) || (function () {
    var extendStatics = Object.setPrototypeOf ||
        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
    return function (d, b) {
        extendStatics(d, b);
        function __() { this.constructor = d; }
        d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
    };
})();
var A = /** @class */ (function () {
    function A() {
    }
    return A;
}());
var B = /** @class */ (function (_super) {
    __extends(B, _super);
    function B() {
        return _super !== null && _super.apply(this, arguments) || this;
    }
    return B;
}(A));

Наследование Javascript согласноДокументы Mozilla это:

B.prototype = Object.create(A.prototype);
B.prototype.constructor = B;

Части, которые я не понимаю в сгенерированном коде Typescript, это

1. Какова цель этой линии? Похоже, он копирует все ключи A в B? Это что-то вроде взлома для статических свойств?

var extendStatics = Object.setPrototypeOf ||
        ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
        function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };

2. Что это делает?

function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());

Я не понимаю эту часть:(__.prototype = b.prototype, new __())

Почему функция B () возвращает это?

return _super !== null && _super.apply(this, arguments) || this;

Если кто-то может объяснить мне это построчно, я был бы благодарен.

Ответы на вопрос(0)

Ваш ответ на вопрос