国产探花免费观看_亚洲丰满少妇自慰呻吟_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ā)表

圖片精選

主站蜘蛛池模板: 奉化市| 亳州市| 古丈县| 德保县| 阿鲁科尔沁旗| 临海市| 阳信县| 崇仁县| 贞丰县| 松桃| 郯城县| 建湖县| 建宁县| 伽师县| 新平| 天峨县| 互助| 汉川市| 新巴尔虎左旗| 永丰县| 镇原县| 台前县| 棋牌| 江都市| 恩施市| 中牟县| 枣阳市| 康定县| 垫江县| 萨迦县| 沙湾县| 河西区| 昌图县| 灌南县| 丹凤县| 如皋市| 广东省| 利津县| 惠东县| 竹山县| 广东省|