vuecli4打包优化-cdn加速

459 阅读1分钟

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>
<%}%>