React + Typescript: 开启 HMR/Hot Loader
2020-02-09
更新日期: 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" },
yarn add react-app-rewire-hot-loader react-app-rewired react-hot-loader --dev
在项目根目录创建一个 config-overrides.js
文件, 是项目的根目录,不是 src 文件夹, 要放到和 package.json 同级。
const rewireReactHotLoader = require('react-app-rewire-hot-loader') /* config-overrides.js */ module.exports = function override (config, env) { config = rewireReactHotLoader(config, env) return config }
然后再跟节点上面执行 hot()
:
// 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
Replace 'react-scripts' with 'react-app-rewired' in package.json
"scripts": { "start": "react-app-rewired start", "build": "react-app-rewired build", "test": "react-app-rewired test --env=jsdom", "eject": "react-app-rewired eject" },
关于本文
文章标题 | React + Typescript: 开启 HMR/Hot Loader |
发布日期 | 2020-02-09 |
文章分类 | Tech |
相关标签 | #JS #NodeJS #Redux |
留言板
PLACE_HOLDER
PLACE_HOLDER
PLACE_HOLDER
PLACE_HOLDER