Webpack学习笔记(3)

1.如何使用babel-loader?

webpack自身可以加载js模块,不能转化js代码如果打包js文件会原封不动传到浏览器,如果当前浏览器支持ES6代码则可以正常显示,若浏览器版本过低则不支持,需要使用babel-loader结合babel和webpack对js文件解析。

安装:npm install babel-loader @babel/core @babel/preset-env

  • babel-loader:在webpack中应用babel解析ES6的桥梁;
  • @babel/core:babel核心模块;
  • @babel/preset-env:babel预设,一组babel插件的集合

webpack.config.js中配置:

在hello.js中写两个函数:

打包后的js文件在bundle.js中显示:

其中regeneratorRuntime是webpack打包生成的全局辅助函数,由babel生成,用于兼容async/await的语法。

安装 regeneratorRuntime需要@babel/runtime,@babel/plugin-transform-runtime两个插件,配置一下:

2.代码分离

把文件分到不同的bundle中,bundle是打包出来的文件,可以按需加载或者并行加载,代码分离可以获取更小的bundle以及控制资源加载的优先级,合理使用有利于优化加载时间。

常用分离方法:

  • 使用entry配置手动分离代码(如果多个入口,多个入口共享的文件会重复打包)
  • 使用Entry dependencies或SplitChunksPlugin去重和分离代码
  • 使用模块的内联函数import调用来分离代码

2.1方法一:入口节点

webpack.config.js中配置两个entry,所以对应着有两个出口文件filename:

app.html在可以看到两个文件都被引用:

anothe-module.js中使用loadsh库:

使用webpack打包后,可以看到:

another.bundles.js的文件更大1.37mb,因为使用了loadsh,loadsh也被打包到了another.bundles.js中。如果这时在index.js也使用loadsh,会发现index.bundle.js变为2.39mb,是因为loadsh也打包了。

loadsh分别被打包了,重复打包到各自的chunk里,这是入口起点打包的缺点。

2.2方法二:防止重复

webpack.config.js中配置entry为对象形式增加dependOn属性,和shared:

app.html在可以看到两个文件都被引用并且增加了一个shared.bundle.js:

使用webpack打包后,可以看到:

通过将重复的打包到shared.bundle.js中在引用使用,减少了内存占用。

另一种实现方法使用插件split-chunks-plugin。

webpack.config.js中增加一个splitChunks的配置项:

使用webpack打包后,可以看到重复的loadsh被分离出:

2.3方法三:动态导入

新建一个async.mmodule.js 动态导入loadsh:

在index.js 正常导入:

可以直接实现将loadsh文件分离出去:

那么如果静态导入,可否与动态导入一起做代码抽离呢?

一旦加入了静态资源就要配置splitsChunks,才可以正常运行,不会重复打包。

3.懒加载

动态导入的意义,实现懒加载(按需加载)是一种很好的优化王爷的方法,这种方法把代码在逻辑断点处分离开,然后再一些代码块中完成某些操作后,立即引用或即将引入另外一些新的代码块,这样加快了应用的初始加载速度,减轻了代码块的总体体积,因为有一些代码块可能永远不加载。

举例子,写一个math.js暴露两个函数add,minus.

在index.js中插入一个button,点击按钮时动态引入math.js,实现add():

这样就可以实现懒加载,只有当用户点击button时才会打包math.js,通过魔法注释:/*webpackChunkName: 'math*/打包后的文件名为math.bundle.js,其中.bundle是我们自己加的后缀。

4.预获取、预加载模块

动态导入的意义2,在声明import时,使用下面这些内置指令,可以让webpack输出"resource hint(资源提示)",来告知浏览器:

prefetch(预获取):将来某些导航下可能需要的资源;

preload(预加载):当前导航下可能需要资源;

预获取加入新的注释: webpackPrefetch: true

prefetch(预获取)的意义在于党首页面的内容都加载完毕后,在网络空闲时再去加载打包好的math.bundle.js文件。

预加载加入新的注释: webpackPreload: true

preload(预加载)与懒加载类似,prefetch更优秀些。

相关推荐
日 近 长 安 远37 分钟前
[学习笔记-AI基础篇]03_Transfommer与GPT架构学习
笔记·gpt·学习
干饭小白1 小时前
ffmpeg使用流程
笔记
啊我不会诶1 小时前
BD202402跑步 线性求逆元 素数筛 数学
学习·算法·补题
chennalC#c.h.JA Ptho2 小时前
iPad os
经验分享·笔记·架构·电脑
明月清了个风2 小时前
工作笔记-----IAP的相关内容
arm开发·笔记·iap·嵌入式软件·程序升级
Virgil1392 小时前
【DL学习笔记】各种卷积操作总结(深度可分离、空洞、转置、可变形)
笔记·深度学习·学习
慕y2742 小时前
Java学习第一百零一部分——网关(Gateway)
java·网络·学习
wrynhyxa2 小时前
回归的wry
经验分享·笔记
特种加菲猫3 小时前
从exec到Shell:深度解析Linux进程等待,程序替换与自主Shell实现
linux·笔记
小眼睛FPGA4 小时前
【盘古100Pro+开发板实验例程】FPGA学习 | 腐蚀膨胀 | 图像实验指导手册
科技·学习·ai·fpga开发·fpga