babel-plugin-minify-constant-folding
Example
In
JavaScript
"a" + "b"
2 * 3;
4 | 3;
"b" + a + "c" + "d" + g + z + "f" + "h" + "i"
[a, b, c].concat([d, e], f, g, [h]);
["a", "b", "c"].join();
["a", "b", "c"].join('@');
[1, 2, 3].length;
[1, 2, 3][1];
[1, 2, 3].shift();
[1, 2, 3].slice(0, 2);
[a, b, c].pop();
[a, b, c].reverse();
"a,b,c".split(",");
"abc"[0];
"abc".charAt();
"abc".charAt(1);
"abc".length;
Out
JavaScript
"ab";
6;
7;
"b" + a + "cd" + g + z + "fhi";
[a, b, c, d, e, f, g, h];
"a,b,c";
"a@b@c";
3;
2;
2;
[1, 2];
c;
[c, b, a];
["a", "b", "c"];
"a";
"a";
"a";
"b";
3;
Installation
- npm
- Yarn
- pnpm
npm install babel-plugin-minify-constant-folding --save-dev
yarn add babel-plugin-minify-constant-folding --dev
pnpm add babel-plugin-minify-constant-folding --save-dev
Usage
With a configuration file (Recommended)
babel.config.json
{
"plugins": ["minify-constant-folding"]
}
Via CLI
Shell
babel --plugins minify-constant-folding script.js
Via Node API
JavaScript
require("@babel/core").transformSync("code", {
plugins: ["minify-constant-folding"]
});
Options
tdz
- Account for TDZ (Temporal Dead Zone)
tip
You can read more about configuring plugin options here