Vue项目总结webpack常规打包优化方案

49次阅读

共计 2038 个字符,预计需要花费 6 分钟才能阅读完成。

由于新建项目发版打包时间大概需要 30 分钟,发版时 严重 拖慢 下班 时间,所以特意查看了相关文档来优化打包速度,争取早点下班,^_^。

分析打包文件

要优化,先分析。我们先要知道到底是哪里拖慢我们的打包速度呢?

打包后生成文件分析

可以利用 webpack-bundle-analyzer 插件来分析我们打包后生成的文件

  • 安装
npm i webpack-bundle-analyzer -D
  • 使用

修改 webpack.prod.conf.js 文件

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin

// 构建完成后,浏览器会自动打开 localhost:8080
webpackConfig.plugins.push(
  new BundleAnalyzerPlugin({
    analyzerPort: 8080,
    generateStatsFile: false
  })
)

通过图片可以看到打包后文件的具体信息

打包进度条显示,可以查看到打包进度百分比

simple-progress-webpack-plugin可以显示打包百分比

  • 安装
npm i simple-progress-webpack-plugin -D
  • 使用

修改 webpack.prod.conf.js 文件

const SimpleProgressWebpackPlugin = require('simple-progress-webpack-plugin')
...
  plugins: [new SimpleProgressWebpackPlugin()
  ]
...

效果如下:

资源与依赖包的控制

通过上面进度可以看到,打包过程中,卡顿在压缩的地方过长,当项目越来越臃肿的时候,我们要需要对项目静态资源以及依赖包进行整理,

  • 图片过大的可以压缩,这里推荐一个还不错的压缩链接
  • 项目中没有使用的依赖可以删除,可以按需引用的依赖,按需引用

项目里面使用 ElementUIEcharts都是全部引用挂在 Vue.prototype 上,现都改为按需引用。

减少文件搜索范围

  • 设置 resolve.alias 字段,避免打包时如果使用相对路径访问或着 import 文件时会层层去查找解析文件
resolve: {
  alias: {'@': resolve('src')
  }
}
  • 合理配置 extensions 扩展名

resolve.extensions能够自动解析确定的扩展,但是如果 extensions 扩展名过多,会导致解析过程过多,所以我们要合理配置扩展名,不要过多配置扩展名,项目引用多的文件,扩展名放在前面,我司项目中多的是 vuejs 文件,可以只引用这两种。

resolve: {extensions: ['.vue', '.js']
}
  • loader预处理文件增加 include 匹配特定条件

预处理各种文件时指定匹配目录后,webpack解析文件时就不会循环查找其他目录,加快解析速度。

happypack多线程执行

webpack执行预处理文件时单线程的,我们可以使用 happypack 来多线程处理文件。

  • 安装
npm i happypack  -D
  • 使用

修改 webpack.base.js 文件

const happyThreadPool = HappyPack.ThreadPool({size: os.cpus().length });
module: {
  rules: [
    {
      test: /\.js$/,
      loader: 'happypack/loader?id=babel', // 原始 loader 替换成 `happypack/loader`
      include: [resolve('src')]
    }
  ]
},
plugins: [
  new HappyPack({
    // id 标识 需要处理的 loader
    id: 'babel',
    // loader 配置和原始配置一样
    loaders: [
      {
        loader: 'babel-loader',
        options: {presets: ['es2015'],
          cacheDirectory: true
        }
      }
    ],
    threadPool: happyThreadPool
  })
]

babel-plugin-dynamic-import-node异步加载

babel-plugin-dynamic-import-node插件是使import() 替换成 require 编译

  • 安装
npm i babel-plugin-dynamic-import-node -D
  • 使用

修改.babelrc 文件

"env": {
  "development": {"plugins": ["dynamic-import-node"]
  },
  "production": {"plugins": ["dynamic-import-node"]
  }
}

注意 :使用插件build 后没有 chunk files 文件。

总结

项目经过以上优化,打包从 30 分钟,到 2 分钟,整体还有优化空间,可以使用其他 cdndll 等优化方式。

文章首发于 imondo.cn;其他系列文章:

组件通信处理方案

正文完
 0