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运行原理图:

相关推荐
_AaronWong1 小时前
Electron 实现仿豆包划词取词功能:从 AI 生成到落地踩坑记
前端·javascript·vue.js
cxxcode1 小时前
I/O 多路复用:从浏览器到 Linux 内核
前端
用户5433081441941 小时前
AI 时代,前端逆向的门槛已经低到离谱 — 以 Upwork 为例
前端
JarvanMo1 小时前
Flutter 版本的 material_ui 已经上架 pub.dev 啦!快来抢先体验吧。
前端
恋猫de小郭2 小时前
AI 可以让 WIFI 实现监控室内人体位置和姿态,无需摄像头?
前端·人工智能·ai编程
哀木2 小时前
给自己整一个 claude code,解锁编程新姿势
前端
程序员鱼皮2 小时前
GitHub 关注突破 2w,我总结了 10 个涨星涨粉技巧!
前端·后端·github
UrbanJazzerati2 小时前
Vue3 父子组件通信完全指南
前端·面试
是一碗螺丝粉2 小时前
5分钟上手LangChain.js:用DeepSeek给你的App加上AI能力
前端·人工智能·langchain
wuhen_n2 小时前
双端 Diff 算法详解
前端·javascript·vue.js