react中的tree-shaking的一些疑问
目的:首先直接抛出问题在ts头部中我引入了一段代码再根据环境变量去决定是否去执行改代码
预期:打包出来的文件并没有因为是生产环境而减少改文件的大小
代码如下:
//httpLogin.ts
import mockAdapterFunc from "mock";
const { PUBLIC_URL: basename, REACT_APP_NEED_MOCK: needMock } = process.env;
needMock && mockAdapterFunc(http);
//mock.js
import { AxiosInstance } from "axios";
var MockAdapter = require("axios-mock-adapter");
export default function mockAdapterFunc (http: AxiosInstance) {
var mock = new MockAdapter(http, { onNoMatch: "passthrough" });
mock.onPost("/sso/logxxxin").reply(200, {
user: "whidy",
});
}
需要说明的是npm run build中needMock是为false 不执行后面的方法
打包出的代码分析图如下
如果手动删除axios-mock-adapter是不存在的
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
tree-shaking是在构建模块代码时根据代码顶部import语句生成dependicens graph是进行的,属于静态编译阶段进行的,如果你要在这种运行阶段才决定是否引入一个模块,你可以了解一下webpack的异步模块