reactjs - 为什么在 webpack 构建后我的基本 React 应用程序很重?
问题描述
我有一个基本的 React 应用程序(2 个小页面和一个 redux 商店),它应该很轻。但是在构建最终包时,webpack 告诉我包是 1.12 MiB,而建议的限制是 244 KiB。然而,我已经通过 Terser 插件和代码拆分进行了优化。
这是我的 webpack.config.js:
const path = require("path");
const TerserPlugin = require("terser-webpack-plugin");
const Dotenv = require("dotenv-webpack");
const HtmlWebpackPlugin = require("html-webpack-plugin");
module.exports = () => {
const env = require("dotenv").config({ path: __dirname + "/.env" });
return {
mode: "development",
entry: "./src/Index.js",
output: {
path: path.join(__dirname, "./dist"),
filename: "[name].[hash].bundle.js",
publicPath: "/",
},
resolve: {
extensions: [".js", "jsx", ".json"],
alias: {
components: path.resolve(__dirname, "src/components/"),
pages: path.resolve(__dirname, "src/pages/"),
store: path.resolve(__dirname, "src/store/"),
src: path.resolve(__dirname, "src/"),
},
},
module: {
rules: [
{
test: /\.(js|jsx)$/,
exclude: /node_modules/,
use: { loader: "babel-loader" },
},
{ test: /\.css$/, use: ["style-loader", "css-loader"] },
{ test: /\.(png|svg|jpg|gif)$/, use: ["file-loader"] },
{ test: /\.html$/, use: [{ loader: "html-loader" }] },
],
},
devServer: {
historyApiFallback: true,
port: 3000,
hot: true,
},
plugins: [
new HtmlWebpackPlugin({
template: "./src/index.html",
}),
new Dotenv(),
],
optimization: {
minimize: true,
minimizer: [new TerserPlugin()],
splitChunks: { chunks: "all" },
},
};
};
这是我的 package.json:
{
"name": "app",
"version": "1.0.0",
"main": "index.js",
"license": "MIT",
"scripts": {
"start": "webpack-dev-server --mode development --open --hot",
"build": "webpack --mode production",
},
"dependencies": {
"react": "^16.13.1",
"react-dom": "^16.13.1",
"react-redux": "^7.2.0",
"react-router-dom": "^5.2.0",
"redux": "^4.0.5"
},
"devDependencies": {
"@babel/core": "^7.10.3",
"@babel/plugin-transform-runtime": "^7.10.3",
"@babel/preset-env": "^7.10.3",
"@babel/preset-react": "^7.10.1",
"babel-loader": "^8.1.0",
"dotenv-webpack": "^1.8.0",
"html-loader": "^1.1.0",
"html-webpack-plugin": "^4.3.0",
"terser-webpack-plugin": "^3.0.6",
"webpack": "^4.43.0",
"webpack-cli": "^3.3.12",
"webpack-dev-server": "^3.11.0"
}
}
如何解决这个问题?
解决方案
推荐阅读
- jbpm - 在 JBPM 与 Drools 的集成中没有触发子业务规则
- databricks - 授予用户/组对 Databricks 工作区中所有笔记本的读取权限
- python - 使用谷歌分析跟踪 REST API 调用/
- javascript - Highcharts JS-为两个系列的工具提示添加第三个变量
- angular - 从 chrome 检查隐藏存储在网站上的视频文件
- python - 如何在多个条目小部件上绑定鼠标操作
- php - php中的递增函数出错
- r - R如何将不同类型的变量打印到一个txt文件中
- google-apps-script - Google App Script - 列出所有包含的工作表
- php - 如何检查是否定义了索引?