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

首頁 > 開發 > JS > 正文

webpack自動打包和熱更新的實現方法

2024-05-06 16:52:43
字體:
來源:轉載
供稿:網友

webpack常用配置

webpack dev server

  • 功能:自動打包文件
  • 配置dev server:在webpack.config.client.js中配置
  const path = require('path');  const HTMlPlugin = require('html-webpack-plugin');    // 判斷是否是開發環境  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){    // 開發環境    config.devServer = {      host: '0.0.0.0',//可以使用ip訪問      port:'8888',      contentBase: path.join(__dirname,'../dist'),//打包后的文件      overlay:{        errors:true //直接在網頁上顯示錯誤      },      publicPath:'/public',      historyApiFallback:{        index:'/public/index.html'      }      }  }  module.exports = config;

在package.json中增加一條命令來進行自動打包

cross-env是為了兼容mac windows liunx的環境變量,需要安裝。

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

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

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持VeVb武林網。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 石台县| 德格县| 大兴区| 项城市| 张北县| 婺源县| 新民市| 浑源县| 西充县| 墨江| 永城市| 诸暨市| 南平市| 大丰市| 茶陵县| 阿拉尔市| 南澳县| 顺平县| 南江县| 凤翔县| 郸城县| 桓仁| 临桂县| 鸡泽县| 安龙县| 湖州市| 通道| 伊通| 磴口县| 四川省| 和静县| 屯门区| 通许县| 吴川市| 洞口县| 建昌县| 元谋县| 乐清市| 双桥区| 连江县| 张掖市|