zoukankan      html  css  js  c++  java
  • vue-cli项目打包优化(webpack3.0)

    1.修改source-map配置:此配置能大大减少打包后文件体积。

      a.首先修改 /config/index.js 文件:  

      // /config/index.js
      dev环境:devtool: 'eval'(最快速度)
      prod环境:productionSourceMap: false(关闭source-map)
    
      b.然后修改 /src/main.js 文件,关闭生产环境的调试信息
      // /src/main.js
      const isDebug_mode = process.env.NODE_ENV !== 'production'
      Vue.config.debug = isDebug_mode
      Vue.config.devtools = isDebug_mode
      Vue.config.productionTip = isDebug_mode
    

      

    2.启用happypack多核构建项目
     
      安装happypack后,修改 /build/webpack.base.conf.js 文件即可
      
      npm install happypack --save-dev
     
      // /build/webpack.base.conf.js
      const HappyPack = require('happypack')
      const os = require('os')
      const happyThreadPool = HappyPack.ThreadPool({ size: os.cpus().length })
      
      // 增加HappyPack插件
      plugins: [
       new HappyPack({
        id: 'happy-babel-js',
        loaders: ['babel-loader?cacheDirectory=true'],
        threadPool: happyThreadPool,
       })
       ]
      // 修改引入loader
      {
       test: /.js$/,
       // loader: 'babel-loader',
       loader: 'happypack/loader?id=happy-babel-js', // 增加新的HappyPack构建loader
       include: [resolve('src'), resolve('test')]
      }
    

      

     
    3.启用DllPlugin和DllReferencePlugin预编译库文件
       
      这是最复杂也是提升效果最明显的一步,原理是将第三方库文件单独编译打包一次,以后的构建都不需要再编译打包第三方库
      
       a.增加 build/webpack.dll.config.js 文件,并在其中配置需要单独DLL化的模块
        
    const path = require("path")
    const webpack = require("webpack")
     
    module.exports = {
     // 你想要打包的模块的数组
     entry: {
      vendor: ['vue/dist/vue.esm.js', 'axios', 'vue-router', 'iview']
     },
     output: {
      path: path.join(__dirname, '../static/js'), // 打包后文件输出的位置
      filename: '[name].dll.js',
      library: '[name]_library'
     },
     plugins: [
      new webpack.DllPlugin({
       path: path.join(__dirname, '.', '[name]-manifest.json'),
       name: '[name]_library',
       context: __dirname
      }),
      // 压缩打包的文件
      new webpack.optimize.UglifyJsPlugin({
       compress: {
        warnings: false
       }
      })
     ]
    }
    

     b. 在 build/webpack.dev.conf.js 和 build/webpack.prod.conf.js 增加如下插件

    new webpack.DllReferencePlugin({
      context: __dirname,
      manifest: require('./vendor-manifest.json')
    })
    

     c.在 /package.json 增加命令  

    "dll": "webpack --config ./build/webpack.dll.config.js"
    

     d.在 /index.html 增加DLL化JS引入(必须首先引入)

    <script src="/static/js/vendor.dll.js"></script>
    

     e.执行构建

    npm run dll(这一步会生成build/vendor-manifest.json和static/js/vendor.dll.js)
    npm run dev 或 npm run build
    

      

     4.通过 externals 配置来提取常用库,引用外链

        具体查看官方文档:https://webpack.docschina.org/configuration/externals/
  • 相关阅读:
    review37
    review36
    review35
    linux 下 安装mysql
    安装yum
    hadoop mapreduce 计算平均气温的代码,绝对原创
    hadoop mapreduce 计算平均气温的代码,绝对原创
    Mysql命令大全
    Mysql命令大全
    约瑟夫问题
  • 原文地址:https://www.cnblogs.com/zifayin/p/9105339.html
Copyright © 2011-2022 走看看