参考答案:
Tree shaking 是一种通过清除多余代码方式来优化项目打包体积的技术,专业术语叫 Dead code elimination。
虽然 tree shaking 的概念在 1990 就提出了,但直到 ES6 的 ES6-style
模块出现后才真正被利用起来。
在ES6以前,我们可以使用CommonJS引入模块:require(),这种引入是动态的,也意味着我们可以基于条件来导入需要的代码:
1let dynamicModule; 2// 动态导入 3if (condition) { 4 myDynamicModule = require("foo"); 5} else { 6 myDynamicModule = require("bar"); 7}
但是CommonJS规范无法确定在实际运行前需要或者不需要某些模块,所以CommonJS不适合tree-shaking机制。在 ES6 中,引入了完全静态的导入语法:import。这也意味着下面的导入是不可行的:
1// 不可行,ES6 的import是完全静态的 2if (condition) { 3 myDynamicModule = require("foo"); 4} else { 5 myDynamicModule = require("bar"); 6}
我们只能通过导入所有的包后再进行条件获取。如下:
import foo from "foo";
import bar from "bar";
if (condition) {
// foo.xxxx
} else {
// bar.xxx
}
ES6的import语法可以完美使用tree shaking,因为可以在代码不运行的情况下就能分析出不需要的代码。
看完上面的分析,你可能还是有点懵,这里我简单做下总结:因为tree shaking只能在静态modules下工作。ECMAScript 6 模块加载是静态的,因此整个依赖树可以被静态地推导出解析语法树。所以在 ES6 中使用 tree shaking 是非常容易的。
看完上面的分析,相信这里你可以很容易的得出题目的答案了:
最近更新时间:2024-08-10