Vai al contenuto principale

@babel/plugin-proposal-function-bind

Traduzione Beta Non Ufficiale

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

Dettagli

JavaScript
obj::func;
// is equivalent to:
func.bind(obj)

::obj.func;
// is equivalent to:
obj.func.bind(obj);

obj::func(val);
// is equivalent to:
func
.call(obj, val)

::obj.func(val);
// is equivalent to:
obj.func.call(obj, val);

Esempio

Base

JavaScript
const box = {
weight: 2,
getWeight() {
return this.weight;
},
};

const { getWeight } = box;

console.log(box.getWeight()); // prints '2'

const bigBox = { weight: 10 };
console.log(bigBox::getWeight()); // prints '10'

// Can be chained:
function add(val) {
return this + val;
}

console.log(bigBox::getWeight()::add(5)); // prints '15'

Utilizzo con document.querySelectorAll

Può essere molto utile quando utilizzato con document.querySelectorAll:

JavaScript
const { map, filter } = Array.prototype;

let sslUrls = document
.querySelectorAll("a")
::map(node => node.href)
::filter(href => href.substring(0, 5) === "https");

console.log(sslUrls);

document.querySelectorAll restituisce un elemento NodeList che non è un array semplice, quindi normalmente non puoi usare la funzione map su di esso, e devi usarlo in questo modo: Array.prototype.map.call(document.querySelectorAll(...), node => { ... }). Il codice sopra che utilizza :: funzionerà perché è equivalente a:

JavaScript
const { map, filter } = Array.prototype;

let sslUrls = document.querySelectorAll("a");
sslUrls = map.call(sslUrls, node => node.href);
sslUrls = filter.call(sslUrls, href => href.substring(0, 5) === "https");

console.log(sslUrls);

Auto binding del this

Quando nulla è specificato prima dell'operatore ::, la funzione viene associata al proprio oggetto:

JavaScript
$(".some-link").on("click", ::view.reset);
// is equivalent to:
$(".some-link").on("click", view.reset.bind(view));

Installazione

npm install --save-dev @babel/plugin-proposal-function-bind

Utilizzo

Con un file di configurazione (Consigliato)

babel.config.json
{
"plugins": ["@babel/plugin-proposal-function-bind"]
}

Tramite CLI

Shell
babel --plugins @babel/plugin-proposal-function-bind script.js

Tramite Node API

JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-proposal-function-bind"],
});

Riferimenti