国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 語言 > JavaScript > 正文

webpack自動打包和熱更新的實現(xiàn)方法

2024-05-06 15:37:30
字體:
供稿:網(wǎng)友

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中增加一條命令來進行自動打包

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)   }) }

通過以上配置就能達到局部熱更新了,修改代碼,頁面會實時修改,不會刷新頁面了。

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持錯新站長站。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表

圖片精選

主站蜘蛛池模板: 买车| 霞浦县| 神木县| 延吉市| 肥东县| 怀柔区| 壤塘县| 南汇区| 广南县| 山西省| 加查县| 湛江市| 迁西县| 岱山县| 星子县| 堆龙德庆县| 浦城县| 沙洋县| 临颍县| 登封市| 涞源县| 凉山| 白银市| 金平| 舞阳县| 三原县| 新沂市| 璧山县| 林州市| 沁源县| 胶州市| 玉溪市| 通化市| 崇阳县| 扶绥县| 横山县| 济阳县| 苏尼特右旗| 道孚县| 文成县| 新疆|