@babel/plugin-transform-new-target
This plugins allows babel to transform new.target
meta property into a
(correct in most cases) this.constructor
expression.
Example
function Foo() {
console.log(new.target);
}
Foo();
new Foo();
class Foo {
constructor() {
console.log(new.target);
}
}
class Bar extends Foo {
}
new Foo();
new Bar();
Caveats
This plugin relies on this.constructor
, which means super
must
already have been called when using untransformed classes.
class Foo {}
class Bar extends Foo {
constructor() {
new.target;
super();
}
}
Additionally, this plugin cannot transform all Reflect.construct
cases
when using newTarget
with ES5 function classes (transformed ES6 classes).
function Foo() {
console.log(new.target);
}
function Bar() {
Foo.call(this);
}
Bar.prototype = Object.create(Foo.prototype);
Bar.prototype.constructor = Bar;
function Baz() {}
Reflect.construct(Foo, []);
Reflect.construct(Foo, [], Bar);
Reflect.construct(Bar, []);
Reflect.construct(Foo, [], Baz);
Installation
npm install --save-dev @babel/plugin-transform-new-target
Usage
Via .babelrc
(Recommended)
.babelrc
{
"plugins": ["@babel/plugin-transform-new-target"]
}
Via CLI
babel --plugins @babel/plugin-transform-new-target script.js
Via Node API
require("@babel/core").transform("code", {
plugins: ["@babel/plugin-transform-new-target"]
});