由于最近开发的个人博客(Vue + node)在使用过程中,发现网络加载有点慢,所以打算对它进行一次优化。本次优化的目标如下:
index.html
设置成 no-cache
,这样每次请求的时候都会比对一下 index.html
文件有没变化,如果没变化就使用缓存,有变化就使用新的 index.html
文件。maxAge: 1000 * 60 * 60 * 24 * 365
。以上三点结合,就能实现文件的精确缓存。
换句话说,在一年内,如果我的个人博客没有进行任何更新,那同一台电脑在这段时间内访问网站不会发起任何请求;如果有某个文件更新了,只会请求新的文件,旧的文件依旧从缓存读取。
小知识:
通过配置 output 的 filename 属性可以实现这个需求。filename 属性的值选项中有一个 [contenthash],它将根据文件内容创建出唯一 hash。当文件内容发生变化时,[contenthash] 也会发生变化。
output: {
filename: ‘[name].[contenthash].js‘,
chunkFilename: ‘[name].[contenthash].js‘,
path: path.resolve(__dirname, ‘../dist‘),
},
由于引入的第三方库一般都比较稳定,不会经常改变。所以将它们单独提取出来,作为长期缓存是一个更好的选择。
这里需要使用 webpack4 的 splitChunk 插件 cacheGroups 选项。
optimization: {
runtimeChunk: {
name: ‘manifest‘ // 将 webpack 的 runtime 代码拆分为一个单独的 chunk。
},
splitChunks: {
cacheGroups: {
vendor: {
name: ‘chunk-vendors‘,
test: /[\\/]node_modules[\\/]/,
priority: -10,
chunks: ‘initial‘
},
common: {
name: ‘chunk-common‘,
minChunks: 2,
priority: -20,
chunks: ‘initial‘,
reuseExistingChunk: true
}
},
}
},
除了提取第三方库外,结合 Vue 使用 import 动态引入组件还能实现按需加载。
app.use((req, res, next) => { // 将 index.html 设为 no-cache
if(req.url == ‘/‘) {
res.setHeader(‘Cache-control‘, ‘no-cache‘)
}
next()
})
app.use(express.static(‘dist‘, {
etag: false,
maxAge: 1000 * 60 * 60 * 24 * 365, // 缓存一年
})) // 将dist设为根目录
详细的代码可以看一下我的个人博客项目。
原文:https://www.cnblogs.com/woai3c/p/13089905.html