Webpack中搭建本地服务dev-server

开发过程中关于实现文件内容发生变化时,可监听文件变化内容、自动完成编译热更新,webpack提供了几种可选方式:

1. webpack watch mode监听文件变化

watch可在导出配置中添加或者在webpack 启动命令中添加--watch

注意:watch 的配置可以监听到文件的变化、但是不具备自动刷新浏览器,即实现开发过程中的热更新 HMR,需要通过 webpack 的另一插件实现该功能 webpack-dev-server

2. webpack-dev-server常用基本配置

npm i webpack-dev-server -D

webpack-dev-server在根据配置编译文件后,不会写入任何输出文件,通过将文件保留在内存中,搭建本地服务,读取内存来输出在指定端口实现开发中项目热更新。

关于 devServer 的常用配置项:

javascript 复制代码
  devServer: {
    hot: true, // 开始热更新
    // hot: 'only',  // 编译构建失败时不刷新浏览器页面 保留之前打印记录 热更新
    port: 7777, // 监听请求的端口
    open: true,  // 自动打开服务地址
    compress: true, // 是否开始 gzip 压缩
    proxy: { // 代理配置
      "/api":{
        target: "代理的目标服务器地址",
        pathRewrite: { "^/api": "" },
        changeOrigin: true, // 是否保留本机请求头host
        secure: false // 是否开启安全协议  开启后无法代理 https协议地址
      }
    },
    historyApiFallback: true // 路由跳转失败时返回上一级页面  可自行配置指定路由的跳转配置
  },

关于compress的压缩效果:

true:

false:

3. webpack-dev-server 的基本实现原理

webpack-dev-server 是运用另一个node 框架 express开启本地的静态资源服务,和开启Socket服务;

  • express server负责直接提供静态资源的服务(打包后的资源直接被浏览器请求和解析);
  • HMR Socket Server,是一个socket的长连接建立连接后双方可以通信,当服务器监听到对应的模块发生变化时,会生成两个文件.json(manifest文件)和.js文件(update chunk),通过长连接,可以直接将这两个文件主动发送给客户端(浏览器)浏览器拿到两个新的文件后,通过HMR runtime机制,加载这两个文件,并且针对修改的模块进行更新;

HMR运行原理图:

相关推荐
yanyu-yaya5 小时前
前端面试题
前端·面试·前端框架
二哈喇子!5 小时前
使用NVM下载Node.js管理多版本
前端·npm·node.js
GGGG寄了5 小时前
HTML——文本标签
开发语言·前端·html
2501_944521596 小时前
Flutter for OpenHarmony 微动漫App实战:推荐动漫实现
android·开发语言·前端·javascript·flutter·ecmascript
Amumu121387 小时前
Vue核心(三)
前端·javascript·vue.js
CoCo的编程之路7 小时前
2026 前端效能革命:如何利用智能助手实现“光速”页面构建?深度横评
前端·人工智能·ai编程·comate·智能编程助手·文心快码baiducomate
RFCEO7 小时前
HTML编程 课程五、:HTML5 新增语义化标签
前端·html·html5·跨平台·语义化标签·可生成安卓/ios·html最新版本
2501_944521597 小时前
Flutter for OpenHarmony 微动漫App实战:图片加载实现
android·开发语言·前端·javascript·flutter·php
雨中深巷的油纸伞8 小时前
vue 项目部署到iis后 浏览器刷新404
前端·javascript·vue.js
谢尔登8 小时前
从源码视角来看Pinia!
前端·javascript·vue.js