webpack自動打包和熱更新的實(shí)現(xiàn)方法
webpack常用配置
webpack dev server
- 功能:自動打包文件
- 配置dev server:在webpack.config.client.js中配置
const path = require('path');
const HTMlPlugin = require('html-webpack-plugin');
// 判斷是否是開發(fā)環(huán)境
const isDev = process.env.NODE_ENV === 'development'
const config = {
entry: {
app: path.join(__dirname,'../client/app.js')
},
output: {
filename: '[name].[hash].js',
path: path.join(__dirname,'../dist'),
publicPath: '/public'
},
module: {
rules: [
{
test: /.jsx$/,
loader: 'babel-loader'
},
{
test: /.js$/,
loader: 'babel-loader',
exclude: [
path.join(__dirname,'../node_modules')
]
}
]
},
plugins:[
new HTMlPlugin({
template:path.join(__dirname,'../client/template.html')
})
]
}
//新增
if(isDev){
// 開發(fā)環(huán)境
config.devServer = {
host: '0.0.0.0',//可以使用ip訪問
port:'8888',
contentBase: path.join(__dirname,'../dist'),//打包后的文件
overlay:{
errors:true //直接在網(wǎng)頁上顯示錯誤
},
publicPath:'/public',
historyApiFallback:{
index:'/public/index.html'
}
}
}
module.exports = config;
在package.json中增加一條命令來進(jìn)行自動打包
cross-env是為了兼容mac windows liunx的環(huán)境變量,需要安裝。
npm install cross-env -D
"dev:client": "cross-env NODE_ENV=development webpack-dev-server --config build/webpack.config.client.js"
hot module replacemennt
功能:自動刷新頁面
配置hot module:
安裝react-hot-loader
npm install react-hot-loader -D
在webpack.config.client.js中配置
const webpack = require('webpack')
if(isDev){
config.entry ={
app:[
"react-hot-loader/patch",
path.join(__dirname,'../client/app.js')
]
}
...省略
config.plugins.push(new webpack.HotModuleReplacementPlugin())
}
在client/app.js中配置
...省略
import { AppContainer } from 'react-hot-loader';
const root = document.getElementById('root')
const render = Component =>{
aaa.hydrate(
<AppContainer>
<Component />
</AppContainer>,
root
)
}
render(App)
if(module.hot){
module.hot.accept('./App.jsx',()=>{
const NextApp = require('./App.jsx').default
render(NextApp)
})
}
通過以上配置就能達(dá)到局部熱更新了,修改代碼,頁面會實(shí)時修改,不會刷新頁面了。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript實(shí)現(xiàn)全角半角檢測的方法
這篇文章主要介紹了javascript實(shí)現(xiàn)全角半角檢測的方法,涉及javascript針對字符遍歷與檢測的實(shí)現(xiàn)技巧,具有一定參考借鑒價值,需要的朋友可以參考下2015-07-07
bootstrap-table后端分頁功能完整實(shí)例
這篇文章主要介紹了bootstrap-table后端分頁功能,結(jié)合完整實(shí)例形式分析了bootstrap-table后端請求、數(shù)據(jù)分頁功能具體步驟與實(shí)現(xiàn)技巧,需要的朋友可以參考下2020-06-06
layui的布局和表格的渲染以及動態(tài)生成表格的方法
今天小編就為大家分享一篇layui的布局和表格的渲染以及動態(tài)生成表格的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-09-09
詳解JavaScript發(fā)送埋點(diǎn)請求的兩種方式
對于發(fā)送埋點(diǎn)請求這種應(yīng)用場景,我們有兩種簡單的處理方式:動態(tài)創(chuàng)建<script>和<img>兩種方式。本文就詳細(xì)講講二種方式的實(shí)現(xiàn),需要的可以參考一下2022-06-06

