5.webpack中的webpack-dev-server

本文介绍了webpack-dev-server,它是webpack的开发服务器,提供HTTP服务、文件变化自动刷新、Source Map支持。它基于webpack-dev-middleware和webpack-hot-middleware实现模块热替换(HMR)。详细解析了webpack-dev-server的配置选项,如contentBase、port、compress、hot等,以及如何启用HTTPS、设置代理和自定义headers。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在日常开发中,我们可能需要以下几个功能:

  • 提供HTTP服务而不是使用本地文件预览;
  • 监听文件变化并自动刷新网页, 做到实时预览;
  • 支持Source Map, 以方便调试;
    webpack的原生支持上述2、3点内容,再结合官方提供的开放工具DevServer也可以很方便的做到第一点。DevServer会启动一个HTTP服务器用于服务网页请求,同时会帮助启动webpack,并接收webpack发出的文件变更信号,通过websocket协议自动刷新网页做到实时预览。

1.webpack-dev-middleware和 webpack-hot-middleware

webpack-dev-middleware
假设我们在服务端使用 express 开发一个站点,同时也想利用 webpack 对静态资源进行打包编译,那么在开发环节,每次修改完文件后,都得先执行一遍 webpack 的编译命令,等待新的文件打包到本地,再做进一步调试。虽然咱们可以利用 webpack 的 watch mode 来监听变更、自动打包,但等待 webpack 重新执行的过程往往很耗时。webpack-dev-middleware 的出现很好地解决了上述问题,它会开启 watch mode 监听文件变更,并自动地在内存中快速地重新打包、提供新的 bundle。
说白了就是 —— 自动编译(watch mode)+速度快(全部走内存)

webpack-hot-middleware
webpack-hot-middleware可以让页面也能自动更新呢,提供的这种能力称为 HMR(即模块热替换(hot module replacement)的简称,它可以在应用运行的时候,不需要刷新页面,就可以直接替换、增删模块。)。
webpack 可以通过配置 webpack.HotModuleReplacementPlugin 插件来开启全局的 HMR 能力,开启后 bundle 文件会变大一些,因为它加入了一个小型的 HMR 运行时(runtime),当你的应用在运行的时候,webpack 监听到文件变更并重新打包模块时,HMR 会判断这些模块是否接受 update,若允许,则发信号通知应用进行热替换。

2. webpack-dev-server

webpack-dev-server 相对前两个工具多了个“server”,实际上它的确也是在 webpack-dev-middleware 的基础上多套了一层壳来提供 CLI 及 server 能力(这也是为何我称 webpack-dev-middleware 是 webpack-dev-server 他爹)。

“devServer”的 webpack-dev-server 配置项:

const path = require('path');
module.exports = {
   
   
    entry: './app.js',
    output: {
   
   
        publicPath: "/assets/",
        filename: 'bundle.js'
    },
    devServer: {
   
    //新增配置项
        contentBase: path.join
### 安装适用于 Node.js 16.8 的 `webpack-dev-server` 为了在 Node.js 16.8 环境中安装并配置 `webpack-dev-server`,可以遵循以下说明: #### 准备工作 确保已经正确设置了 Node.js 版本为 16.8。可以通过 nvm(Node Version Manager)来管理多个版本的 Node.js 并切换到所需版本。 #### 创建项目目录与初始化 npm 如果还没有创建新的项目,则先建立一个新的文件夹作为项目的根目录,并通过命令行工具进入该文件夹执行如下命令以初始化npm包: ```bash npm init -y ``` 这一步会自动生成一个默认设置的 `package.json` 文件[^2]。 #### 安装 WebpackWebpack Dev Server 接着,在终端输入下列命令来安装 webpack 及其开发服务器插件 `webpack-dev-server` 到当前项目依赖项中: 对于非全局安装的情况,推荐使用这种方式因为这样能更好地控制不同项目之间的依赖关系差异: ```bash npm install --save-dev webpack webpack-cli webpack-dev-server ``` 此时会在本地项目的 `node_modules/.bin/` 路径下找到可执行文件 `webpack` 和 `webpack-dev-server` [^3]。 #### 修改 Package Scripts 配置 打开 `package.json` 文件并将 `"dev"` 字段更新为启动 `webpack-dev-server` 所需参数的形式,例如: ```json { "scripts": { "build": "cross-env NODE_ENV=production webpack --config config/webpack.prod.js", "dev": "cross-env NODE_ENV=development webpack-dev-server --open" } } ``` 注意这里的 `-c` 参数已被简化为直接指定配置文件路径的方式;同时增加了 `--open` 参数以便于自动打开浏览器访问服务地址 。 #### 启动开发模式下的 Webpack Dev Server 完成上述更改之后就可以运行下面这条简单的命令来开启带有热重载功能的服务端口了: ```bash npm run dev ``` 此操作将会读取 `package.json` 中定义好的脚本指令从而调用对应的命令去编译资源以及监听变更事件 [^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值