• Webpack--devServer的常用配置


    原文网址:Webpack--devServer的常用配置_IT利刃出鞘的博客-CSDN博客

    简介

    说明

            本文介绍webpack的devServer常用的一些配置。

    配置格式

    配置文件为:webpack.config.js(如果是vue-cli,配置文件为vue.config.js)

    1. module.exports = {
    2. //...
    3. devServer: {
    4. proxy: {
    5. '/api': 'http://localhost:3000',
    6. },
    7. },
    8. };

    client

    overlay

    类型

    boolean = true object: { errors boolean = true, warnings boolean = true }

    作用

    覆盖屏幕。

    示例:当出现编译错误或警告时,在浏览器中显示全屏覆盖。

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     client: {
    5.       overlay: true,
    6.     },
    7.   },
    8. };

    通过命令行使用:

    npx webpack serve --client-overlay

    如需禁用:

    npx webpack serve --no-client-overlay

    示例:只显示错误信息

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     client: {
    5.       overlay: {
    6.         errors: true,
    7.         warnings: false,
    8.       },
    9.     },
    10.   },
    11. };

    通过命令行使用:

    npx webpack serve --client-overlay-errors --no-client-overlay-warnings

    open

    类型

    boolean string object [string, object]

    作用

    告诉 dev-server 在服务器已经启动后打开浏览器。设置其为 true 以打开你的默认浏览器。

    open 所有配置项

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     open: {
    5.       target: ['first.html', 'http://localhost:8080/second.html'],
    6.       app: {
    7.         name: 'google-chrome',
    8.         arguments: ['--incognito', '--new-window'],
    9.       },
    10.     },
    11.   },
    12. };

    示例:启动后打开浏览器

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     open: true,
    5.   },
    6. };

    通过命令行使用:

    npx webpack serve --open

    如需禁用:

    npx webpack serve --no-open

    示例:在浏览器中打开指定页面

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     open: ['/my-page'],
    5.   },
    6. };

    通过命令行使用:

    npx webpack serve --open /my-page

    示例:在浏览器中打开多个指定页面

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     open: ['/my-page', '/another-page'],
    5.   },
    6. };

    通过命令行使用:

    npx webpack serve --open /my-page --open /another-page

    示例:提供要使用的浏览器名称,而不是默认名称

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     open: {
    5.       app: {
    6.         name: 'google-chrome',
    7.       },
    8.     },
    9.   },
    10. };

    通过命令行使用:

    npx webpack serve --open-app-name 'google-chrome'

            浏览器应用程序名称与平台相关。不要在可重用模块中硬编码它。例如,'Chrome' 在 macOS 是 'Google Chrome',在 Linux 是 'google-chrome',在 Windows 是 'chrome'。

    port

    类型

    'auto' string number

    作用

    指定监听请求的端口号。

    示例:指定监听请求的端口号

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     port: 8080,
    5.   },
    6. };

    通过命令行使用:

    npx webpack serve --port 8080

    示例:自动使用可用的端口

    port 配置项不能设置为 null 或者空字符串,要想自动使用一个可用端口请使用 port: 'auto':

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     port: 'auto',
    5.   },
    6. };

    通过 CLI 使用:

    npx webpack serve --port auto

    proxy

    类型

    object [object, function]

    作用

            当拥有单独的 API 后端开发服务器并且希望在同一域上发送 API 请求时,代理某些 URL 可能会很有用。

            开发服务器使用功能强大的 http-proxy-middleware 软件包。 查看其 documentation 了解更多高级用法。 请注意,http-proxy-middleware 的某些功能不需要target键,例如 它的 router 功能,但是仍然需要在此处的配置中包含target,否则webpack-dev-server 不会将其传递给 http-proxy-middleware。

    示例:指定后端地址

    使用后端在 localhost:3000 上,可以使用它来启用代理:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: {
    5.       '/api': 'http://localhost:3000',
    6.     },
    7.   },
    8. };

    现在,对 /api/users 的请求会将请求代理到 http://localhost:3000/api/users。

    示例:重写路径

    如果不希望传递/api,则需要重写路径:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: {
    5.       '/api': {
    6.         target: 'http://localhost:3000',
    7.         pathRewrite: { '^/api': '' },
    8.       },
    9.     },
    10.   },
    11. };

    示例:支持https的后端服务器

            默认不支持使用无效证书的HTTPS的后端服务器。 如果需要,可以这样修改配置:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: {
    5.       '/api': {
    6.         target: 'https://other-server.example.com',
    7.         secure: false,
    8.       },
    9.     },
    10.   },
    11. };

    示例:代理部分内容

    有时不想代理所有内容。 可以基于函数的返回值绕过代理。

    在该功能中,可以访问请求,响应和代理选项。

    1. 返回 null 或 undefined 以继续使用代理处理请求。
    2. 返回 false 会为请求产生 404 错误。
    3. 返回提供服务的路径,而不是继续代理请求。

    例如,对于浏览器请求,想要提供 HTML 页面服务,但是代理 API 请求。 可以执行以下操作:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: {
    5.       '/api': {
    6.         target: 'http://localhost:3000',
    7.         bypass: function (req, res, proxyOptions) {
    8.           if (req.headers.accept.indexOf('html') !== -1) {
    9.             console.log('Skipping proxy for browser request.');
    10.             return '/index.html';
    11.           }
    12.         },
    13.       },
    14.     },
    15.   },
    16. };

    示例:将多个路径代理到同一目标

            如果想将多个特定路径代理到同一目标,则可以使用一个或多个带有 context 属性的对象的数组:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: [
    5.       {
    6.         context: ['/auth', '/api'],
    7.         target: 'http://localhost:3000',
    8.       },
    9.     ],
    10.   },
    11. };

    示例:代理对root的请求

    默认不会代理对 root 的请求。 要启用根代理,应将 devMiddleware.index 选项指定为false:

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     devMiddleware: {
    5.       index: false, // specify to enable root proxying
    6.     },
    7.     proxy: {
    8.       context: () => true,
    9.       target: 'http://localhost:1234',
    10.     },
    11.   },
    12. };

    示例:不保留主机头的来源

            默认情况下,代理时会保留主机头的来源,可以将 changeOrigin 设置为 true 以覆盖此行为。 在某些情况下,例如使用 name-based virtual hosted sites,它很有用。

    webpack.config.js

    1. module.exports = {
    2.   //...
    3.   devServer: {
    4.     proxy: {
    5.       '/api': {
    6.         target: 'http://localhost:3000',
    7.         changeOrigin: true,
    8.       },
    9.     },
    10.   },
    11. };

  • 相关阅读:
    【趣味随笔】农业机器人的种类与发展前景
    90%的人以为会用ThreadPoolExecutor了,看了这10张图再说吧
    【JavaEE基础与高级 第59章】Java中的反射、Class对象介绍使用、反射获取构造方法Constructor(上篇)
    vue3 解决警告: Promise returned from xxx is ignored 和 $router未定义
    CSDN21天学习挑战赛之折半查找
    金仓数据库 KingbaseES PL/SQL 过程语言参考手册(12. 异常处理)
    前端周刊第十三期
    JAVA代码审计——SQL注入靶场审计01
    .npmrc 使用详解
    杂谈 跟编程无关的事情21
  • 原文地址:https://blog.csdn.net/feiying0canglang/article/details/126560143