跳至主要內容

@babel/plugin-transform-numeric-separator

資訊

此外掛程式包含在 @babel/preset-env 中,在 ES2021

範例

十進位數字字面量

JavaScript
let budget = 1_000_000_000_000;

// What is the value of `budget`? It's 1 trillion!
//
// Let's confirm:
console.log(budget === 10 ** 12); // true

二進位數字字面量

JavaScript
let nibbles = 0b1010_0001_1000_0101;

// Is bit 7 on? It sure is!
// 0b1010_0001_1000_0101
// ^
//
// We can double check:
console.log(!!(nibbles & (1 << 7))); // true

十六進位數字字面量

JavaScript
// Messages are sent as 24 bit values, but should be
// treated as 3 distinct bytes:
let message = 0xa0_b0_c0;

// What's the value of the upper most byte? It's A0, or 160.
// We can confirm that:
let a = (message >> 16) & 0xff;
console.log(a.toString(16), a); // a0, 160

// What's the value of the middle byte? It's B0, or 176.
// Let's just make sure...
let b = (message >> 8) & 0xff;
console.log(b.toString(16), b); // b0, 176

// What's the value of the lower most byte? It's C0, or 192.
// Again, let's prove that:
let c = message & 0xff;
console.log(c.toString(16), b); // c0, 192

八進位數字字面量

揮手表情符號

八進位數字非常適合用於權限,但以 0o0000 形式表示時看起來也更好看。在此處使用分隔符號沒有實際好處。

安裝

npm install --save-dev @babel/plugin-transform-numeric-separator

用法

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

透過 CLI

Shell
babel --plugins @babel/plugin-transform-numeric-separator script.js

透過 Node API

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

其他資訊

如果您需要進一步將 ES2015 十進位、二進位、十六進位和八進位數字表示編譯成其 ES2015 前的數字字面形式,請新增 "@babel/plugin-transform-literals" 外掛程式

資訊

@babel/plugin-transform-literals 已包含在 @babel/preset-env 中。

babel.config.json
{
"presets": ["@babel/preset-env"],
"plugins": ["@babel/plugin-transform-numeric-separator"]
}
{
"plugins": ["@babel/plugin-transform-numeric-separator", "@babel/plugin-transform-literals"]
}

參考資料