前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >React + Typescript: 开启 HMR/Hot Loader

React + Typescript: 开启 HMR/Hot Loader

作者头像
szhshp
发布2022-09-21 10:25:54
3690
发布2022-09-21 10:25:54
举报
文章被收录于专栏:szhshp 的第四边境中转站

更新日期: 2020-02-09 "devDependencies": { "react-app-rewire-hot-loader": "^2.0.1", "react-app-rewired": "^2.1.5", "react-hot-loader": "^4.12.19" }, "dependencies": { "react": "^16.12.0", "react-dom": "^16.12.0", "react-router-dom": "^5.1.2", "react-scripts": "3.3.1", "typescript": "~3.7.2" },

Installation

代码语言:javascript
复制
yarn add react-app-rewire-hot-loader react-app-rewired react-hot-loader --dev

Usage

config-override

在项目根目录创建一个 config-overrides.js 文件, 是项目的根目录,不是 src 文件夹, 要放到和 package.json 同级。

代码语言:javascript
复制
const rewireReactHotLoader = require('react-app-rewire-hot-loader')

/* config-overrides.js */
module.exports = function override (config, env) {
  config = rewireReactHotLoader(config, env)
  return config
}

hot()

然后再跟节点上面执行 hot():

代码语言:javascript
复制
// App.js - react-hot-loader >= 4.5.4
import React from 'react'
import { hot } from 'react-hot-loader/root'

const App = () => <div>Hello World!</div>

export default process.env.NODE_ENV === "development" ? hot(App) : App


// For react-hot-loader < 4.5.4, use `hot(module)(App)` instead
// export default process.env.NODE_ENV === "development" ? hot(module)(App) : App

package.json

Replace 'react-scripts' with 'react-app-rewired' in package.json

代码语言:javascript
复制
  "scripts": {
    "start": "react-app-rewired start",
    "build": "react-app-rewired build",
    "test": "react-app-rewired test --env=jsdom",
    "eject": "react-app-rewired eject"
  },

参考文献

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-02-09,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • Installation
  • Usage
    • config-override
      • hot()
        • package.json
        • 参考文献
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档