webpack自動(dòng)打包和熱更新的實(shí)現(xiàn)方法
webpack常用配置
webpack dev server
- 功能:自動(dòng)打包文件
- 配置dev server:在webpack.config.client.js中配置
const path = require('path'); const HTMlPlugin = require('html-webpack-plugin'); // 判斷是否是開(kāi)發(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){ // 開(kāi)發(fā)環(huán)境 config.devServer = { host: '0.0.0.0',//可以使用ip訪問(wèn) port:'8888', contentBase: path.join(__dirname,'../dist'),//打包后的文件 overlay:{ errors:true //直接在網(wǎng)頁(yè)上顯示錯(cuò)誤 }, publicPath:'/public', historyApiFallback:{ index:'/public/index.html' } } } module.exports = config;
在package.json中增加一條命令來(lái)進(jìn)行自動(dòng)打包
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
功能:自動(dòng)刷新頁(yè)面
配置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) }) }
通過(guò)以上配置就能達(dá)到局部熱更新了,修改代碼,頁(yè)面會(huì)實(shí)時(shí)修改,不會(huì)刷新頁(yè)面了。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例
這篇文章主要介紹了bootstrap-table實(shí)現(xiàn)表頭固定以及列固定的方法示例,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03JS應(yīng)用正則表達(dá)式轉(zhuǎn)換大小寫(xiě)示例
這篇文章主要介紹了JS應(yīng)用正則表達(dá)式轉(zhuǎn)換大小寫(xiě),以首字母大寫(xiě),其它字母小寫(xiě)為例,喜歡的朋友可以參考下2014-09-09鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)
這篇文章主要介紹了鼠標(biāo)懸停小圖標(biāo)顯示大圖標(biāo)的相關(guān)資料,需要的朋友可以參考下2016-01-01利用Three.js實(shí)現(xiàn)3D三棱錐立體特效
Three.js是基于原生WebGL封裝運(yùn)行的三維引擎,在所有WebGL引擎中,Three.js是國(guó)內(nèi)文資料最多、使用最廣泛的三維引擎。本文將用Three.js實(shí)現(xiàn)3D三棱錐立體特效,感興趣的可以了解一下2022-06-06用Javascript做flash做的事..才完成的一個(gè)類.Auntion Action var 0.1
用Javascript做flash做的事..才完成的一個(gè)類.Auntion Action var 0.1...2007-02-02JavaScript實(shí)現(xiàn)簡(jiǎn)易登錄注冊(cè)頁(yè)面
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)簡(jiǎn)易登錄注冊(cè)頁(yè)面,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下<BR>2022-01-01使用typescript類型來(lái)實(shí)現(xiàn)快排詳情
這篇文章主要介紹了使用typescript類型來(lái)實(shí)現(xiàn)快排詳情,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-08-08JavaScript更改原始對(duì)象valueOf的方法
這篇文章主要介紹了JavaScript更改原始對(duì)象valueOf的方法,涉及javascript使用自定義valueOf函數(shù)替換掉原始o(jì)bject中valueOf的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-03-03微信小程序?qū)崿F(xiàn)點(diǎn)擊按鈕后修改顏色
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)點(diǎn)擊按鈕后修改顏色,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-12-12