Webpack学习笔记(4)

1.缓存

可以通过命中缓存降低网络流量,是网站加站速度更快。

然而在部署新版本时,不更改资源的文件名,浏览器可能认为你没有更新,所以会使用缓存版本。

由于缓存存在,获取新的代码成为问题。

接下来将配置webpack使得生成的文件会被缓存,并且变化时又能请求到新的文件。

如果文件内容改变了,文件名没变,浏览器会使用缓存,所以通过修改output的filename可以实现根据文件内容变化同时修改文件名。

在webpack.config.js修改filename配置:

2.缓存第三方库

将第三方库(如loadsh等)打包缓存到浏览器,自己的代码发生变化时才去更新,第三方代码始终使用缓存,所以就配置单独打包第三方库缓存到浏览器,利用client的长效缓存机制,命中缓存来消除请求,并减少向server获取资源,保证client代码和server代码版本一致。下面来举例实现

第三方库的特点是都在node_modules文件夹下。

在webpack.config.js配置splitChunks:

可以看到第三方库被打包为一个vendors.xxx.js文件:

将js文件放到单独的scripts文件夹下,修改一下出口文件filename即可:

相关推荐
LO嘉嘉VE2 分钟前
学习笔记二十二:神经网络的几起几落
笔记·神经网络·学习
The_cute_cat8 分钟前
Vim的初步学习
学习·编辑器·vim
一字白首11 分钟前
Node.js 入门搞定核心内置模块(fs/path/http/querystring)
学习·http·node.js
wdfk_prog12 分钟前
[Linux]学习笔记系列 -- [block]fops
linux·笔记·学习
C语言不精12 分钟前
一种在 ESP32-S3 上取巧的清晰度检测方案
c语言·stm32·嵌入式硬件·学习
丝斯201116 分钟前
AI学习笔记整理(23)—— AI核心技术(深度学习7)
人工智能·笔记·学习
烤麻辣烫17 分钟前
黑马程序员苍穹外卖(新手)DAY10
java·开发语言·学习·spring·intellij-idea
●VON25 分钟前
Flutter vs React Native vs 原生开发:有何不同?
学习·flutter·react native·react.js·openharmony
Freshman小白30 分钟前
《英文科技论文写作与学术报告》网课答案(雨课堂、学堂在线...)
网络·学习·答案
Bin二叉34 分钟前
南京大学cpp复习——第二部分(继承)
开发语言·c++·笔记·学习