Webpack部署本地服务器

Webpack部署本地服务器

目录


目的

完成自动编译
常用方式: webpack-dev-server

webpack-dev-server 是一个用于开发环境的 Web 服务器,它集成了 Webpack,并提供了实时重新加载和热替换等功能。以下是一个简单的 webpack-dev-server 配置和使用示例:

  1. 首先,确保已经安装了 webpack, webpack-cliwebpack-dev-server。如果没有安装,可以使用以下命令进行安装:
bash 复制代码
npm install --save-dev webpack webpack-cli webpack-dev-server -D   // 开发环境
  1. 在项目根目录下创建一个名为 webpack.config.js 的文件,用于存放 Webpack 配置信息:
javascript 复制代码
const path = require('path');

module.exports = {
  entry: './src/index.js',
  output: {
    filename: 'main.js',
    path: path.resolve(__dirname, 'dist'),
  },
  devServer: {
    contentBase: path.join(__dirname, 'dist'),
    // 是否为静态文件开启 gzip compression 默认是false
    compress: true,
    port: 9000,
    // open 是否打开浏览器, 默认是 false 
    open: true,
    hot: true,
  },
};

这个配置文件定义了入口文件为 src/index.js,输出文件为 dist/main.js,并配置了 webpack-dev-server 的相关参数。

  1. 在项目的 package.json 文件中添加一个启动脚本:
json 复制代码
{
  "scripts": {
    "serve": "webpack serve"
  }
}
  1. 现在,可以通过运行 npm run serve 命令来启动 webpack-dev-server。服务器将在端口 9000 上启动,并在默认浏览器中打开 http://localhost:9000。当你对 src/index.js 文件进行更改时,服务器将自动重新加载和热替换。

认识模块热替换(HMR)

什么是 HMR

 HMR的全称是Hot Module Replacement,翻译为模块热替换;

 模块热替换是指在 应用程序运行过程中,替换、添加、删除模块,而无需重新刷新整个页面;

HMR 通过如下几种方式, 来提高开发的速度

 不重新加载整个页面,这样可以保留某些应用程序的状态不丢失;

只更新需要变化的内容,节省开发的时间;

修改了css、js源代码,会立即在浏览器更新,相当于直接在浏览器的devtools中直接修改样式;

如何使用 HMR

默认情况下,webpack-dev-server已经支持HMR,我们只需要开启即可**(默认已经开启);**

在不开启HMR的情况下,当我们修改了源代码之后,整个页面会自动刷新,使用的是live reloading;

host 配置

◼ host设置主机地址:

 默认值是localhost;

 如果希望其他地方也可以访问,可以设置为 0.0.0.0;

port、open、compress

port设置监听的端口,默认情况下是8080

◼ open是否打开浏览器:

 默认值是false,设置为true会打开浏览器;

 也可以设置为类似于 Google Chrome等值;

◼ compress是否为静态文件开启gzip compression:

 默认值是false,可以设置为true;

相关推荐
升讯威在线客服系统8 分钟前
如何通过 Docker 在没有域名的情况下快速上线客服系统
java·运维·前端·python·docker·容器·.net
AsBefore麦小兜10 分钟前
Vite vs Webpack
前端·webpack
LaughingZhu10 分钟前
PH热榜 | 2025-02-23
前端·人工智能·经验分享·搜索引擎·产品运营
道不尽世间的沧桑2 小时前
第17篇:网络请求与Axios集成
开发语言·前端·javascript
diemeng11193 小时前
AI前端开发技能变革时代:效率与创新的新范式
前端·人工智能
bin91535 小时前
DeepSeek 助力 Vue 开发:打造丝滑的复制到剪贴板(Copy to Clipboard)
前端·javascript·vue.js·ecmascript·deepseek
勤奋的凯尔森同学5 小时前
webmin配置终端显示样式,模仿UbuntuDesktop终端
linux·运维·服务器·ubuntu·webmin
丁卯4046 小时前
Go语言中使用viper绑定结构体和yaml文件信息时,标签的使用
服务器·后端·golang
chengooooooo6 小时前
苍穹外卖day8 地址上传 用户下单 订单支付
java·服务器·数据库
晴空万里藏片云7 小时前
elment Table多级表头固定列后,合计行错位显示问题解决
前端·javascript·vue.js