前端项目打包优化

1、分析包的体积

1.1 打包的时候 加上--report即可获得打包分析界面;

1.2 webpack-bundle-analyzer 进行打包体积分析;

npm install webpack-bundle-analyzer -D

2、配置

3、运行

 

4、移除 console

借助插件babel-plugin-transform-remove-console 或者 npm install --save-dev @babel/plugin-transform-runtime

并在babel.config.js中配置该插件只能生产阶段生效

module.exports = function (api) {
  api.cache(true);
  return {
    presets: ['@babel/preset-env'],
    plugins: [
      [
        '@babel/plugin-transform-runtime',
        {
          corejs: 3,
          helpers: true,
          regenerator: true,
          useESModules: false,
        },
      ],
    ],
  };
};

5、sourcemap

生产阶段关闭sourcemap,不然会产生 很多map文件,会导致项目过大

  • 9
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
前端项目打包优化可以从以下几个方面入手: 1. 代码压缩:使用 webpack 的 UglifyJSPlugin 或 TerserPlugin 进行代码压缩,减小代码体积; ``` const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); module.exports = { // ... optimization: { minimizer: [ new UglifyJSPlugin({ uglifyOptions: { compress: { warnings: false, drop_console: true,//去除console.log drop_debugger: true,//去除debugger pure_funcs: ['console.log']//指定移除的函数 } } }) ] } }; ``` 2. Tree shaking:使用 webpack 的 optimize.ModuleConcatenationPlugin 进行模块合并,减少代码冗余; ``` const webpack = require('webpack'); module.exports = { // ... plugins: [ new webpack.optimize.ModuleConcatenationPlugin() ] }; ``` 3. 懒加载:使用 webpack 的 import() 方法实现按需加载,减少首屏加载时间; ``` function getComponent() { return import(/* webpackChunkName: "lodash" */ 'lodash').then(_ => { var element = document.createElement('div'); element.innerHTML = _.join(['Hello', 'webpack'], ' '); return element; }).catch(error => 'An error occurred while loading the component'); } getComponent().then(component => { document.body.appendChild(component); }); ``` 4. CDN 加速:使用外部 CDN 加速加载常用库,减少服务器压力和网络请求时间; ``` <script src="https://cdn.bootcdn.net/ajax/libs/react/17.0.1/umd/react.production.min.js"></script> <script src="https://cdn.bootcdn.net/ajax/libs/react-dom/17.0.1/umd/react-dom.production.min.js"></script> ``` 5. 缓存优化:使用 webpack 的 hash 或 chunkhash 为打包文件添加哈希值,实现静态资源缓存,提高页面加载速度; ``` module.exports = { // ... output: { filename: '[name].[chunkhash].js', path: path.resolve(__dirname, 'dist') } }; ``` 以上是一些常见的前端项目打包优化方法,具体实现可以根据项目需求进行调整。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值