React webpack 包大小很大

Posted

技术标签:

【中文标题】React webpack 包大小很大【英文标题】:React webpack bundle size is large 【发布时间】:2021-07-12 03:48:25 【问题描述】:

我有一个使用 react 开发的网站,它只有一个页面,但生产包大小为 1.11 MiB。我正在为这个应用程序使用 firestore、firebase 存储、material-UI、react-redux 运行良好,除了包大小之外一切都很好。

我使用 webpack-bundle-analyzer 来分析包大小,似乎 nodemodules 占用了很大的大小。在这里,我添加了屏幕截图。

我的 webpack 配置文件

    const path = require('path');
var CompressionPlugin = require('compression-webpack-plugin');
const TerserPlugin = require("terser-webpack-plugin");
const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;

module.exports = 
  mode: 'production',
  entry: './src/public/index.js',
  plugins: [
    new BundleAnalyzerPlugin(
      generateStatsFile : true
    ),
    new CompressionPlugin(
      deleteOriginalAssets: false,
      filename: "[path][base].gz",
      algorithm: "gzip",
      test: /\.js$|\.css$|\.html$/,
      threshold: 10240,
      // Compress all assets, including files with `0` bytes size
      // minRatio: Infinity

      // Compress all assets, excluding files with `0` bytes size
      // minRatio: Number.MAX_SAFE_INTEGER
      minRatio: 0.8,
    )

  ],
  optimization: 
    nodeEnv: 'production',
    minimize: true,
    concatenateModules: true,

  ,

  module: 
    rules: [
        test: /\.(jpe?g|png|gif|svg)$/,
        loader: 'image-webpack-loader',
        // This will apply the loader before the other ones
        enforce: 'pre',
      ,
      
        test: /\.m?js$/,
        exclude: /node_modules/,
        use: 
          loader: 'babel-loader',
          options: 
            presets: ['@babel/preset-env'],
            plugins: [
              ["@babel/plugin-proposal-object-rest-spread", 
                "definitions": 
                  "process.env": 
                    "NODE_ENV": "\"production\""
                  
                
              ],
              ['babel-plugin-transform-imports',
                
                  '@material-ui/core': 
                    // Use "transform: '@material-ui/core/$member'," if your bundler does not support ES modules
                    'transform': '@material-ui/core/esm/$member',
                    'preventFullImport': true
                  ,
                  '@material-ui/icons': 
                    // Use "transform: '@material-ui/icons/$member'," if your bundler does not support ES modules
                    'transform': '@material-ui/icons/esm/$member',
                    'preventFullImport': true
                  
                
              ]
            ]
          
        
      

    ]
  ,
  output: 
    path: path.resolve(__dirname, 'build'),
    filename: 'bundle.js'
  
;

我不知道我在这里错过了什么来减少节点模块的大小。如果我们有任何其他减小捆绑包大小的选择,请给我一个建议。

【问题讨论】:

对于 lodash ,您可以通过像 import isEqual from 'lodash'; 这样的结构导入来进行一些优化,然后将 sideEffect:false 添加到您的包 json 中 你可能想探索将你的 js 文件分割成块 有时捆绑包很大是正常的。您可以使用延迟加载,这样客户端就不需要一次下载完整的包。您可以访问reactjs.org/docs/code-splitting.html了解更多信息。 @Spring 我使用了 lodash 的 mapKeys 函数,现在我为此添加了 javascript 函数并删除了 lodash 代码,它减少了 64 kb 也可以尝试使用 preact-compat 的 Preact,这应该是 React 的 10 倍大小,同时保留了与 React 相同的 API。 【参考方案1】:

MaterialUI、lodash 和 webpack 支持 Tree Shaking。 由于您使用了 webpack-bundle-analyser,我假设您的构建过程使用了 webpack。所以你的选择如下:

你可以使用Webpack的Tree Shaking Guide。

Material UI 还有一个Minimizing Bundle Size 指南。

一般来说,压缩包大小的很大一部分是消除死代码。

完成此操作后,您可能需要遵循 React 的 Code Splitting 指南以确保初始加载更快。

【讨论】:

【参考方案2】:

您可以单独导入 lodash 函数

import get from 'lodash/get'

而不是

import  get  from 'lodash'

但我敢打赌,这不会大大减少您的捆绑包大小

【讨论】:

我使用了 lodash 的 mapKeys 函数,现在我为此添加了 javascript 函数并删除了 lodash 代码,它减少了 64 kb【参考方案3】:

确保您在生产模式下运行 webpack。为此,您可以使用 -p 标志运行 webpack,如下所示:

webpack -p

这个小标志做了这两件事来优化你的包大小:

    使用 UglifyJs 启用缩小。它去除了不必要的白色 空格、新行、无法访问的代码等。 将 NODE_ENV 设置为“生产”。这告诉了一些包,比如 React,不包含调试代码。

如果它不适合你,请尝试this

【讨论】:

是的,我正在生产模式下运行 试试看这篇文章linkedin.com/pulse/…【参考方案4】:

如果你想减小构建大小,可以通过这种方式导入函数

import groupBy from 'lodash/groupBy';

不是这个

import  groupBy  from 'lodash';

前者会获取整个 lodash 库的内容,而后者只会获取其中的一个特定块。从而大大减少了构建大小。

【讨论】:

以上是关于React webpack 包大小很大的主要内容,如果未能解决你的问题,请参考以下文章

使用webpack搭建react项目 webpack-react-project

React+Webpack+Webstorm开发环境搭建

webpac入门

Vue打包上线webpack优化插件开启gzip-减少包的大小

聊聊 webpack 打包如何压缩包文件大小

如何最小化 webpack 包的大小?