webpack5 基础配置(4上)模块化原理commonjs esmodule原理。

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

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设置就好,后期再具体再了解其用途在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

coderlin_

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值