最近在学习并使用webpack+react+antd写了一个小项目,也可以说是demo,待全部开发完成后发现webpack的打包文件足足有将近13.3MB,快吓死宝宝了,经过连续几天的学习和调试最后将打包文件缩小到665kb,效果十分显著,网上有许多解决办法,大多对新手都不是很友好,涉及到的知识点十分的多,导致一步一坑,虽然这边文章不是最好的,但通过如下的调试缩小其打包文件。

项目github连接 :https://github.com/2016Messi/webpack3-react-router4

环境参数

react 16.1.1

webpack 3.8.1

antd 3.0.0

react-router-dom 4.2.0

本文涉及到的解决方案

antd按需加载

使用webpack压缩插件:uglifyjs-webpack-plugin

使用webpack的新特性:ModuleConcatenationPlugin

提取第三方库 : 两种方法

将devtool更改为生产环境

1 antd按需加载

antd 是ant-design的缩写,是蚂蚁金服的一款基于react的前端 UI组件,不做过多介绍,总之很强大

antd官网(当前页面向下拉)的组件中有介绍按需加载的使用,这里在写一遍:

使用babel-plugin-import插件

1.1 方法一 (推荐)

1 安装插件 npm install --save-dev babel-plugin-import
2 在根目录下创建.babelrc文件,并把以下代码填入
{
"plugins": [
["import", { "libraryName": "antd", "libraryDirectory": "es", "style": "css" }] // `style: true` 会加载 less 文件
]
}
然后只需从 antd 引入模块即可,无需单独引入样式。等同于下面手动引入的方式
// babel-plugin-import 会帮助你加载 JS 和 CSS
import { DatePicker } from 'antd';

此时此刻这段代码也可以注释掉了 import 'antd/dist/antd.css';

1.2 方法二

手动引入

import DatePicker from 'antd/lib/date-picker';  // 加载 JS
import 'antd/lib/date-picker/style/css'; // 加载 CSS
// import 'antd/lib/date-picker/style'; // 加载 LESS

通过antd的按需加载成功将打包文件从13.3MB缩小到7.73MB

2 使用webpack压缩插件

1 安装

npm i -D uglifyjs-webpack-plugin

2 使用

    //在webpack.config.js文件中做如下配置
const UglifyJSPlugin = require('uglifyjs-webpack-plugin'); plugins: [
new UglifyJSPlugin()
]

通过代码压缩的方式成功将打包文件从7.73MB缩小到7.7MB

3 使用webpack的新特性:ModuleConcatenationPlugin

webpack3.0以上版本新增了一个特性,ModuleConcatenationPlugin,具体效果太过复杂不做过多的介绍,只要能缩小打包文件就足够了,并且没有其他影响

使用方法

//直接在webpack.config.js中写入如下代码即可
plugins: [
new webpack.optimize.ModuleConcatenationPlugin()
]

通过上述方法的修改,成功将打包文件从7.7MB缩小到7.47MB

4 提取第三方库

webpack 在打包过程中,也会将react react-dom react-router 等相关文件一起打包到文件中

4.1 方法一

在webpack.config.js中做如下配置
    entry: {
bundle :__dirname + "/src/js/root.js", //已多次提及的唯一入口文件
vendor: ['react','react-dom','react-router-dom','react-responsive'] //在此处配置
} plugins: [
new webpack.optimize.CommonsChunkPlugin({
name: 'vendor',
filename: 'vendor.bundle.js'
}),
]

经过上面的配置后对应的文件夹中会生成vendor.bundle.js文件,该文件就是公共模块(但是每次打包都会生成公共模块),此时还需在html文件中将公共模块引入,注意:公共模块要放在前面

经过如上配置成功将打包文件从7.47MB缩小至5.04MB

4.2 方法二(推荐)

1 在根目录下创建webpack.dll.config.js文件,并填写如下配置
const path    = require('path');
const webpack = require('webpack'); module.exports = {
entry: {
bundle: ['react','react-dom','react-router-dom','react-responsive'] //提取公共模块
},
output: {
path: path.join(__dirname, 'src/js'),
filename: '[name].dll.js',
library: '[name]_library'
},
plugins: [
new webpack.DllPlugin({
path: path.join(__dirname, 'src/js','[name]-manifest.json'), name: '[name]_library'
})
]
};
2 在 webpack.config.js中做如下配置
        new webpack.DllReferencePlugin({
context: __dirname,
manifest: require('./src/js/bundle-manifest.json')
}),
3 执行 --config webpack.dll.config.js
4 执行 webpack --config webpack.config.js

此时目录下会出现两个文件 bundle-manifest.json 和 bundle.dll.js(公共模块),接下来每次只需打包业务逻辑的代码就可以了,若公共模块版本更新 再次执行 第4步即可。

html目录引用

//注意公共模块要放在前面
<script src="/src/js/bundle.dll.js"></script>
<script src="http://localhost:8080/bundle.js"></script>

经过上述方法处理后成功将打包文件从7.47MB缩小至5.08MB

5 将开发环境改为生产环境

将webpack.config.js中的devtool 设置为 false

devtool: 'false'

此时此刻硕大文件突然就从5.08MB变为了665kb

成功解决react+webpack打包文件过大的问题的更多相关文章

  1. Nginx开启gzip压缩解决react打包文件过大

    用create-react-app创建的react应用打包之后的build js有1M之多. 采用gzip打包传输,可以节约70%左右的带宽 nginx采用gzip打包方式 在nginx配置中添加如下 ...

  2. 14.如何解决使用webpack打包之后,font-awsome路径不对的问题,终极解决方法

    问题描述: 使用webpack打包vue项目,使用font-awsome字体,发现打包之后,font-awsome图标不显示,报错为路径不对 看了下打包的路径,的确路径不对,打包之后font-awso ...

  3. webpack打包文件中的@符号表示什么意思

    在看使用webpack打包的项目代码时,经常会看到在路径中引用@符号 import one from '@/views/one.vue' 那这里的@符号到底表示什么意思呢? 这其实利用了webpack ...

  4. 解决 webpack 打包文件体积过大

    webpack 把我们所有的文件都打包成一个 JS 文件,这样即使你是小项目,打包后的文件也会非常大.下面就来讲下如何从多个方面进行优化. 去除不必要的插件 刚开始用 webpack 的时候,开发环境 ...

  5. 彻底解决 webpack 打包文件体积过大

    http://www.jianshu.com/p/a64735eb0e2b https://segmentfault.com/q/1010000006018592?_ea=985024 http:// ...

  6. webpack打包文件解析

    /** * 对于没有代码分割的,webpack会打包生成main.js一个大的自执行函数 * 函数参数是一个对象,键值分别是路径和模块的函数 * 函数内部定义了一些方法,包括__webpack_req ...

  7. webpack打包文件

    npm init -y//生成package.json npm install webpack webpack-cli --save-dev//安装webpack和webpack-cli根据入口文件. ...

  8. angular 4 开发环境下打包文件过大

    angular 4本地开发环境下,ng server -- port 8080 -o 之后在在浏览器中查看数据请求,其中vendor.bundle.js有8.3mb,而整个传输数据大小为16.3mb ...

  9. 成功解决android studio打包报错

    Win7系统,Android Studio 版本2.3.1,对cpp-empty-test使用了 cocos compile -p android --android-studio,命令 编译打包AP ...

随机推荐

  1. 脱掉Golang的第一层衣裳 golang入坑系列

    读前必读,博客园的文章并非最新,想看最新还是建议点击这里.博客园的文章是为了方便不能FQ的同学,同步而来的.不放在博客园,不是不支持国产,而是博客园的排版太难看了,太难看了,太难看了!而且还没有客户端 ...

  2. PHP常用的函数与小技巧

    密码加密与验证 password_hash - 创建密码的哈希(hash) string password_hash ( string $password , integer $algo [, arr ...

  3. 为Go程序创建最小的Docker Image

    本文将会介绍如何使用docker打包一个golang编写的应用程序,最终的产物就是一个makefile文件,可别小瞧这短短几行代码,涉及的知识点可不少,接下来我们就仔细剖析一下吧. FROM gola ...

  4. mysql数据库表卡死解决方法

    ---恢复内容开始--- 问题引起原因: 由于在执行大量插入操作的时候意外终止程序之后, MySQl的线程并没有被终止,导致表不能打开和操作 -  解决思路就是找到等待的线程并kill -- 查看所有 ...

  5. 一个可扩展的深度学习框架的Python实现(仿keras接口)

    一个可扩展的深度学习框架的Python实现(仿keras接口) 动机 keras是一种非常优秀的深度学习框架,其具有较好的易用性,可扩展性.keras的接口设计非常优雅,使用起来非常方便.在这里,我将 ...

  6. thinkphp3.2.3的使用心得之i方法(零)

    从模板传参到控制器 模板中代码: <volist name="list" id="vo"> <a href="__CONTROLLE ...

  7. 【MAVEN】maven系列--pom.xml标签详解

    pom文件作为MAVEN中重要的配置文件,对于它的配置是相当重要.文件中包含了开发者需遵循的规则.缺陷管理系统.组织.licenses.项目信息.项目依赖性等.下面将重点介绍一下该文件的基本组成与功能 ...

  8. [阿里云部署] Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器

    部署地址:123.56.7.181 Ubuntu+Flask+Nginx+uWSGI+Mysql搭建阿里云Web服务器 这个标题就比之前的"ECS服务器配置Web环境的全过程及参考资料&qu ...

  9. C#开发Windows窗体应用程序的步骤

    使用C#开发应用程序时,一般包括创建项目.界面设计.设置属性.编写程序代码.保存项目.程序运行等6个步骤. 1.创建项目 在Visual Studio2017开发环境中选择“文件”→“新建”→“项目” ...

  10. Python中的列表操作

    Python的列表操作可谓是功能强大且方便(相对于Java)简单.常规的操作就不说了(这不是一个入门教程),介绍几个很有特点的例子 添加 # 追加到结尾(append) li = [1, 2, 3, ...