@Bergi упомянул new.target.prototype
, но я искал конкретный пример, доказывающий, что вы можете получить доступ this
(или, лучше, ссылку на объект, с которым создается клиентский код new
, см. Ниже) без необходимости вызыватьsuper()
вообще .
Обсуждение дешево, покажите код ... Итак, вот пример:
class A { // Parent
constructor() {
this.a = 123;
}
parentMethod() {
console.log("parentMethod()");
}
}
class B extends A { // Child
constructor() {
var obj = Object.create(new.target.prototype)
// You can interact with obj, which is effectively your `this` here, before returning
// it to the caller.
return obj;
}
childMethod(obj) {
console.log('childMethod()');
console.log('this === obj ?', this === obj)
console.log('obj instanceof A ?', obj instanceof A);
console.log('obj instanceof B ?', obj instanceof B);
}
}
b = new B()
b.parentMethod()
b.childMethod(b)
Что выведет:
parentMethod()
childMethod()
this === obj ? true
obj instanceof A ? true
obj instanceof B ? true
Итак, вы можете видеть, что мы эффективно создаем объект типа B
(дочерний класс), который также является объектом типа A
(его родительский класс), и внутри childMethod()
дочернего B
мы this
указываем на объект, obj
который мы создали в B constructor
с помощью Object.create(new.target.prototype)
.
И все это совершенно безразлично super
.
Это использует тот факт, что в JS a constructor
может возвращать совершенно другой объект, когда клиентский код создает новый экземпляр с new
.
Надеюсь, это кому-то поможет.