Mode配置
之前我们打包的时候一直报错,mode属性没有设置。看下基本配置


mode错误

在官网这里可以查到相关信息。
mode可以有三个取值,development production(默认) none
我们默认是设置为production,生产模式,顾名思义要上线了,为了性能优化,要压缩,所以webpack会进行丑化。
当我们设置为development时,会开发模式,开发模式暂时不上线所以无需丑化。

打包后

可以看到就是正常的js文件没有被压缩过。

这三个取值的含义以及不同取值的结果



每个取值其实都做了很多事情,目前只需了解他是干嘛的,还不用关系里面的具体。
模块化原理
webpack允许我们使用各种各样的模块化,如ES MODULE(ES6) COMMONJS(node)等
但浏览器默认不支持commonjs,es6模块化有些旧的浏览器也不支持。但是webpack里面我们可以随便写。那么webpack怎么支持模块化呢?
我们研究四个原理:
Commonjs模块化实现原理
ES Moduls实现原理
commnjs加载ES module的原理(es module导出commonjs导入)
es module加载commonjs的原理
1 commonjs模块化实现原理


代码很简单,方便理解。

可以看到很多代码很杂,把devtool设位source-map设置就好,后期再具体再了解其用途

本文深入探讨了webpack的mode属性在development和production模式下的差异,以及如何在none模式下进行配置。此外,详细解析了webpack如何处理CommonJS和ESModule模块化,包括模块缓存、加载机制和代码打包过程。通过实例分析了webpack内部如何通过函数作用域实现模块化,确保代码整洁并优化性能。
模块化原理commonjs esmodule原理。&spm=1001.2101.3001.5002&articleId=115186570&d=1&t=3&u=0199238afdac42fcb114bfa18470aa60)
741

被折叠的 条评论
为什么被折叠?



