cdn加速优化
cdn优化是指把第三方库比如(vue,vue-router,axios)通过cdn的方式引入项目中,这样vendor.js会显著减少,并且大大提升项目的首页加载速度
前置条件
externals 配置说明 webpack.docschina.org/configurati…
在webpack上追加自定义对象,如:cdn
vue.config.js中配置为
const isProd = process.env.NODE_ENV === 'production';
const externals = {
vue: 'Vue',
'vue-router': 'VueRouter',
'axios': 'axios',
'vuex': 'Vuex'
}
// cdn外链,会插入到index.html中
const cdn = {
dev: {
css: [],
js: []
},
build: {
css: [],
js: [
'https://cdn.jsdelivr.net/npm/vue@2.6.14/dist/vue.min.js',
'https://cdn.jsdelivr.net/npm/vue-router@3.5.3/dist/vue-router.min.js',
'https://cdn.jsdelivr.net/npm/axios@0.24.0/dist/axios.min.js',
'https://cdn.jsdelivr.net/npm/vuex@3.6.2/dist/vuex.min.js'
]
}
}
module.exports = {
configureWebpack: config => {
if (isProd) {
config.externals = externals
}
},
// 是一个函数,会接收一个基于 webpack-chain 的 ChainableConfig 实例。允许对内部的 webpack 配置进行更细粒度的修改
chainWebpack: config => {
config
.plugin('html')
.tap(args => {
if (isProd) {
args[0].cdn = cdn.build
} else {
args[0].cdn = cdn.dev
}
return args
})
},
}
html页面配置为
<% for (var i in htmlWebpackPlugin.options.cdn && htmlWebpackPlugin.options.cdn.js) {%>
<script src="<%=htmlWebpackPlugin.options.cdn.js[i]%>"></script>
<%}%>