@babel/plugin-proposal-function-bind
详情
¥Detail
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);
示例
¥Example
基本的
¥Basic
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'
与 document.querySelectorAll
一起使用
¥Using with document.querySelectorAll
与 document.querySelectorAll
一起使用时会非常方便:
¥It can be very handy when used with document.querySelectorAll
:
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
返回一个不是普通数组的 NodeList
元素,因此你通常不能在其上使用 map
函数,而必须以这种方式使用它:Array.prototype.map.call(document.querySelectorAll(...), node => { ... })
。上面使用 ::
的代码可以工作,因为它相当于:
¥document.querySelectorAll
returns a NodeList
element which is not a plain array, so you normally can't use the map
function on it, and have to use it this way: Array.prototype.map.call(document.querySelectorAll(...), node => { ... })
. The above code using the ::
will work because it is equivalent to:
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 self binding
如果在 ::
运算符之前没有指定任何内容,则函数将绑定到其对象:
¥When nothing is specified before the ::
operator, the function is bound to its object:
$(".some-link").on("click", ::view.reset);
// is equivalent to:
$(".some-link").on("click", view.reset.bind(view));
安装
¥Installation
- npm
- Yarn
- pnpm
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
用法
¥Usage
使用配置文件(推荐)
¥With a configuration file (Recommended)
{
"plugins": ["@babel/plugin-proposal-function-bind"]
}
通过 CLI
¥Via CLI
babel --plugins @babel/plugin-proposal-function-bind script.js
通过 Node API
¥Via Node API
require("@babel/core").transformSync("code", {
plugins: ["@babel/plugin-proposal-function-bind"],
});
参考
¥References