webpack非常的強大,合理的腳手架可以為我們的工作省去眾多繁瑣無意義的工作。其中熱重新整理、熱載入相較於傳統開發大大提高了開發節奏。
從腳手架發現熱重新整理、熱載入的差異
相信大部分的vue開發者都是從vue-cli
開始的,很多初學者歡快的跑著vue專案卻不敢改隨意改變vue-cli的配置(畢竟webpack確實很複雜,vue-cli
也做了很多工作來優化初學者的體驗)。
相比之下react沒有提供一個比較健壯的腳手架了(至少沒有明顯地被我找到,望賜教)。據我知一個是yeoman的 generator-react-webpack
、react的create-react-app
,還有一個不錯的react-starter-kit (熱載入,而且整合了非常多程式碼,參考性很高)。
在學習react
時我就發現了上文提到的react前兩個腳手架提供的是熱重新整理
而非熱載入
。
簡單的區分熱載入與熱重新整理:
- 熱重新整理:檔案內動改動後,整個頁面重新整理,不保留任何狀態(比如輸入過內容的Input表單),相當於webpack幫你摁了F5重新整理
- 熱載入:檔案改動後,以最小的代價改變被改變的區域。儘可能保留改動檔案前的狀態(對input輸入內容後,修改其他標籤的程式碼)
這在雖然兩者相較於傳統開發(手動F5)都提升了開發體驗,但兩者之間的依舊很大,尤其是當專案變得愈發複雜之後,我們必須一勞永逸的解決這個問題(留出更多的時間來開發bug)。
動手修改
從頭配置就是另一個領域了,所以我們直接從vue-cli
開始改動。
下述步驟僅列出關鍵做啟發參考,詳細請參考最後github完整專案
- 刪除vue相關的依賴、檔案等;整個
scr
內的東西都可以刪掉 package.json
依賴加入babel-loader
webpack-dev-server
react-hot-loader
(最關鍵)package.json
命令列設定"dev": "webpack-dev-server --inline --progress --config build/webpack.dev.conf.js"
webpack.base.conf
新增.jsx
檔案需要經過babel-loader
處理,配置options:{plugins:['react-hot-loader/babel']}
.babelrc
presets
加入react
,下方加入plugins:['react-hot-loader/babel']
src
資料夾下建立main.js
(起名要跟webpack配置的入口檔案一致)
import 'core-js/fn/object/assign';
import React from 'react';
import ReactDOM from 'react-dom';
import { hot } from 'react-hot-loader';
import App from './pages/App'; // 自己寫吧
import './assets/css/reset.scss';
// Render the main component into the dom
ReactDOM.render(<App/>, document.getElementById('app'));
export default hot(module)(App); // 熱載入的關鍵
複製程式碼
至此,我們就可以愉快地使用react
體驗熱載入的快♂感了~
問題所在
其實在簡單地修改vue-cli
中的main.js
檔案為react相關程式碼(別忘了配置babel處理jsx)並依舊是熱重新整理。
經過原生程式碼觀察對比後,發現了一個吸引人的名字:
在webpack.dev.conf檔案中:
new webpack.HotModuleReplacementPlugin()
複製程式碼
網上查詢後得知這是實現熱載入的關鍵,它需要程式碼本身具備模組化的性質(這意味著只要像三大框架這樣可編寫可複用元件的框架都能利用這個性質),這樣才可以通過插♂拔程式碼實現熱載入。
而react
的jsx
特效不是HotModuleReplacementPlugin
能搞定的只能老老實實熱重新整理了。
在這種情況下react-hot-loader
呼之欲出。配合官方的使用方法,就能繼續使用熱載入了。
ps: 僅做參考,react的很多程式碼我也處於探索與學習中 配置好的專案地址:gayhub