Vai al contenuto principale

@babel/plugin-transform-new-target

Traduzione Beta Non Ufficiale

Questa pagina è stata tradotta da PageTurner AI (beta). Non ufficialmente approvata dal progetto. Hai trovato un errore? Segnala problema →

informazioni

Questo plugin è incluso in @babel/preset-env

Esempio

JavaScript
function Foo() {
console.log(new.target);
}

Foo(); // => undefined
new Foo(); // => Foo
JavaScript
class Foo {
constructor() {
console.log(new.target);
}
}

class Bar extends Foo {}

new Foo(); // => Foo
new Bar(); // => Bar

Avvertenze

Questo plugin si basa su this.constructor, il che significa che super deve essere già stato chiamato quando si utilizzano classi non trasformate.

JavaScript
class Foo {}

class Bar extends Foo {
constructor() {
// This will be a problem if classes aren't transformed to ES5
new.target;
super();
}
}

Inoltre, questo plugin non può trasformare tutti i casi di Reflect.construct quando si utilizza newTarget con classi funzione ES5 (classi ES6 trasformate).

JavaScript
function Foo() {
console.log(new.target);
}

// Bar extends Foo in ES5
function Bar() {
Foo.call(this);
}
Bar.prototype = Object.create(Foo.prototype);
Bar.prototype.constructor = Bar;

// Baz does not extend Foo
function Baz() {}

Reflect.construct(Foo, []); // => Foo (correct)
Reflect.construct(Foo, [], Bar); // => Bar (correct)

Reflect.construct(Bar, []); // => Bar (incorrect, though this is how ES5
// inheritance is commonly implemented.)
Reflect.construct(Foo, [], Baz); // => undefined (incorrect)

Installazione

npm install --save-dev @babel/plugin-transform-new-target

Utilizzo

Con un file di configurazione (Consigliato)

babel.config.json
{
"plugins": ["@babel/plugin-transform-new-target"]
}

Tramite CLI

Shell
babel --plugins @babel/plugin-transform-new-target script.js

Tramite Node API

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-transform-new-target"],
});