webpack开发环境速度优化
随着项目的增大,项目运行速度会越来越慢,导致影响开发进度。需要提升开发时代码的运行速度。
1. ScopeHoisting作用域提升
该插件在production模式下默认开启。development下需要手动启动。
1 .使用条件
和TreeShaking一样,必须使用ES6的模块,使用import/export语法。
2. 优点:
1)节省内存开销。因为默认每个bundle会打成闭包。
2)减少体积,提升速度。因为如果不使用es模块,默认会包裹一层require。
3. 用法
1. 首先阻止babel将es6的模块进行转换
    {
        test: /\.jsx?$/,
        use: {
          loader: 'babel-loader',
          options: {
            // 切记modules: false
            presets: [['@babel/preset-env', {modules: false}], '@babel/preset-react'],
            plugins: [
              ['@babel/plugin-proposal-decorators', {legacy: true}],
              ['@babel/plugin-proposal-class-properties', {loose: true}]
            ]
          },
        },
        exclude: /node_modules/
      }
2. 引入的第三方库尽量使用es版本
3. 在plugins中配置插件
plugins: [
new webpack.optimize.ModuleConcatenationPlugin(),
]
4. node_modules中的模块优先使用指向es模块的文件
  resolve: {
    mainFields: ['jsnext:main', 'browser', 'main']
  },
2. 热更新
当项目特别大时,页面重新加载会非常缓慢,可以通过热更新,只更改修改的部分。
1. sevServer中开启热更新
module.exports = {
   ...
   devServer: {
       hot: true   //默认开启webpack.HotModuleReplacementPlugin
   }
}
2. css样式热更新
开发模式下使用style-loader, 默认实现了HMR。(css-hot-loader在hot:true时有问题)
      {
        test: /\.css$/,
        use: [
          'style-loader',
          'css-loader'
        ]
      },
3. jsx代码热更新
使用react-hot-loader插件,在需要的模块包裹hot函数。
{
        test: /\.jsx?$/,
        use: {
          loader: 'babel-loader',
          options: {
            presets: [['@babel/preset-env', {modules: false}], '@babel/preset-react'],
            plugins: [
              ['@babel/plugin-proposal-decorators', {legacy: true}],
              ['@babel/plugin-proposal-class-properties', {loose: true}],
              ['react-hot-loader/babel']
            ]
          },
        },
        exclude: /node_modules/
      },
在代码中使用hot方法
import React from 'react';
import { hot } from 'react-hot-loader/root'; function Test(props) {
return(
<div className="hehe">ppp</div>
)
} export default process.env.NODE_ENV === 'development' ? hot(Test) : Test;
也可以不使用该插件,自己实现逻辑
// 尽量在子组件实现该逻辑;它不接受css文件的变化
if(module.hot) {
module.hot.accept(['./example.js'], () => {
ReactDOM.render(<App/>, window.root)
})
}
webpack开发环境速度优化的更多相关文章
- 分离Webpack开发环境与生产环境的配置
		这是Webpack+React系列配置过程记录的第五篇.其他内容请参考: 第一篇:使用webpack.babel.react.antdesign配置单页面应用开发环境 第二篇:使用react-rout ... 
- 从零开始配置TypeScript + React + React-Router + Redux + Webpack开发环境
		转载请注明出处! 说在前面的话: 1.为什么不使用现成的脚手架?脚手架配置的东西太多太重了,一股脑全塞给你,我只想先用一些我能懂的库和插件,然后慢慢的添加其他的.而且自己从零开始配置也能学到更多的东西 ... 
- 从0构建webpack开发环境(一) 一个简单webpack.config.js
		本文基于webpack4.X,使用的包管理工具是yarn 概念相关就不搬运了,直接开始 首先项目初始化 mkdir webpack-demo && cd webpack-demo ya ... 
- webpack开发环境配置和生产环境配置
		开发环境配置 在开发环境下,我们首先考虑的是方便开发,方便代码调试,不需要考虑代码合并和css样式分离这些. 这里主要说三个 :1.css模块化:2.模块热替换功能:3.source-map(代码映射 ... 
- webpack 开发环境与生成环境的  配置
		写在前面 最近学习react,之前做vue项目的时候,一直都是拿来主义,浑浑噩噩,感觉不太好,趁学习react的机会,在顺带学习一下webpack.一般配置文件分两份,为开发环境和生成环境.有此区分, ... 
- 从0构建webpack开发环境(三) 开发环境以及 webpack-dev-server 的使用
		sourceMap 实际应用开发过程中大部分时间都是处于开发模式中,其中需要频繁的修改代码.调试和打包. 但是打包后的代码多个模块压缩到了一个bundle文件,如果出现警告或者异常很难定位到具体模块和 ... 
- react+webpack开发环境配置
		react是目前非常热门的前端框架,提倡组件化开发.所谓的组件,简单理解,就是一个独立的页面部件(包括页面模版,样式,逻辑等),它是一个独立的整体. webpack,是一个模块打包工具,其主要功能,就 ... 
- vue2+webpack 开发环境配置
		前提条件: 1.安装node.js https://nodejs.org/en/ 下载安装合适的平台 2.安装npm 第一步:初始化项目 新建文件夹 E:\app 推荐vue项目目录结构: confi ... 
- webpack开发环境和生产环境切换原理
		在package.json中有如下设置: "scripts": { "dev": "node build/dev-server.js" ... 
随机推荐
- isset和empty,isset和unset,__isset和__unset
			1.isset() 用来检测变量是否存在,如果变量存在,且值不等于零,返回ture empty() 用来检测是否为空,如果变量值值为"".0."0".NULL. ... 
- 47 容器(六)——HashMap
			HashMap的概念 HashMap底层实现了哈希表,这是一种非常重要的数据结构,对于以后我们理解很多技术都有帮助,例如 redis数据库的核心技术和HashMap一样,因此,非常有必要让大家理解. ... 
- Java对象深拷贝浅拷贝总结
			目录 深拷贝 1. 手动new 2. clone方法 3. java自带序列化 4. json序列化 性能测试 深拷贝总结 浅拷贝 1. spring BeanUtils(Apache BeanUti ... 
- VBA 打印及破密
			Sub 打印()ActiveWindow.SelectedSheets.PrintOut Copies:=1, Collate:=TrueCall dyEnd SubSub dy()Dim a%, b ... 
- Java调用WebService方法总结(3)--wsimport调用WebService
			wsimport是JDK自带的把WSDL转成Java的工具,可以很方便的生成调用WebService的代码.文中所使用到的软件版本:Java 1.8.0_191. 1.准备 参考Java调用WebSe ... 
- python3基础之“小练习(2)”
			(十三)创建一个你最喜欢歌手的列表. # singer=list() # singer=['a','b','c'] # print(singer) (十四)创建一个由元组构成的列表,每个元组包含居住过 ... 
- CSS中常见的布局
			一.css中常见的布局有哪些? (1)两列布局 (2)三列布局 (3)弹性布局 (4)圣杯布局 (5)双飞翼布局 二.具体实现 (1)两列布局 https://www.cnblogs.com/qin ... 
- ios开发之NSData
			NSData用于保存字节数组. 初始化 - (instancetype)initWithBytesNoCopy:(void *)bytes length:(NSUInteger)length free ... 
- PHP/Python---百钱百鸡简单实现及优化
			公鸡5块钱一只,母鸡3块钱一只,小鸡一块钱3只,用100块钱买一百只鸡,问公鸡,母鸡,小鸡各要买多少只? 今天看到这题很简单 ,但是随手写出来后发现不是最优的 
- 阿里P7整理20个非常有用的Java程序片段,你知道吗?
			1.字符串有整型的相互转换 String a = String.valueOf(2); //integer to numeric string int i = Integer.parseInt( ... 
