@babel/plugin-proposal-function-bind
Traducción Beta No Oficial
Esta página fue traducida por PageTurner AI (beta). No está respaldada oficialmente por el proyecto. ¿Encontraste un error? Reportar problema →
Detalles
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);
Ejemplo
Básico
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'
Uso con document.querySelectorAll
Puede ser muy práctico cuando se utiliza 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 devuelve un elemento NodeList que no es un array común, por lo que normalmente no puedes usar la función map directamente sobre él, y debes hacerlo de esta manera: Array.prototype.map.call(document.querySelectorAll(...), node => { ... }). El código anterior que usa :: funcionará porque equivale 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 vinculación
Cuando no se especifica nada antes del operador ::, la función se vincula a su objeto:
JavaScript
$(".some-link").on("click", ::view.reset);
// is equivalent to:
$(".some-link").on("click", view.reset.bind(view));
Instalación
- npm
- Yarn
- pnpm
- Bun
npm install --save-dev @babel/plugin-proposal-function-bind
yarn add --dev @babel/plugin-proposal-function-bind
pnpm add --save-dev @babel/plugin-proposal-function-bind
bun add --dev @babel/plugin-proposal-function-bind
Uso
Mediante un archivo de configuración (Recomendado)
babel.config.json
{
"plugins": ["@babel/plugin-proposal-function-bind"]
}
Mediante la CLI
Shell
babel --plugins @babel/plugin-proposal-function-bind script.js
Mediante la API de Node
JavaScript
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-proposal-function-bind"],
});