# 开发服务器选项

# server.host

  • 类型:string | boolean
  • 默认:'localhost'

指定服务器应该监听哪个 IP 地址。 如果将此设置为 0.0.0.0或者 true将监听所有地址,包括局域网和公网地址。

也可以通过 CLI 使用 --host 0.0.0.0--host来设置。

NOTE

在某些情况下,可能响应的是其他服务器而不是 Vite。

第一种情况是 localhost被使用了。Node.js 在 v17 以下版本中默认会对 DNS 解析地址的结果进行重新排序。当访问 localhost时,浏览器使用 DNS 来解析地址,这个地址可能与 Vite 正在监听的地址不同。当地址不一致时,Vite 会打印出来。

你可以设置 dns.setDefaultResultOrder('verbatim') 来禁用这个重新排序的行为。Vite 会将地址打印为 localhost

// vite.config.js
import { defineConfig } from 'vite'
import dns from 'dns'

dns.setDefaultResultOrder('verbatim')

export default defineConfig({
  // omit
})

第二种情况是使用了通配主机地址(例如 0.0.0.0)。这是因为侦听非通配符主机的服务器优先于侦听通配符主机的服务器。

# server.port

  • 类型:number
  • 默认值:5173

指定开发服务器端口。注意:如果端口已经被使用,Vite 会自动尝试下一个可用的端口,所以这可能不是开发服务器最终监听的实际端口。

# server.strictPort

  • 类型:boolean

设为 true时若端口已被占用则会直接退出,而不是尝试下一个可用端口。

# server.https

  • 类型:boolean | https.ServerOptions

启用 TLS + HTTP/2。注意:当 server.proxy 选项 也被使用时,将会仅使用 TLS。

这个值也可以是一个传递给 https.createServer()选项对象

需要一个合法可用的证书。对基本使用的配置需求来说,你可以添加 @vitejs/plugin-basic-ssl 到项目插件中,它会自动创建和缓存一个自签名的证书。但我们推荐你创建和使用你自己的证书。

# server.open

  • 类型:boolean | string

开发服务器启动时,自动在浏览器中打开应用程序。当该值为字符串时,它将被用作 URL 的路径名。如果你想在你喜欢的某个浏览器打开该开发服务器,你可以设置环境变量 process.env.BROWSER(例如 firefox)。你还可以设置 process.env.BROWSER_ARGS来传递额外的参数(例如 --incognito)。

BROWSERBROWSER_ARGS都是特殊的环境变量,你可以将它们放在 .env文件中进行设置,欲了解更多打开浏览器的更多内部细节,请参阅 open 包的源码

示例:

export default defineConfig({
  server: {
    open: '/docs/index.html',
  },
})

# server.proxy

  • 类型:Record<string, string | ProxyOptions>

为开发服务器配置自定义代理规则。期望接收一个 { key: options }对象。任何请求路径以 key 值开头的请求将被代理到对应的目标。如果 key 值以 ^开头,将被识别为 RegExpconfigure选项可用于访问 proxy 实例。

请注意,如果使用了非相对的 基础路径 base ,则必须在每个 key 值前加上该 base

继承自 http-proxy 。完整选项详见 此处 .

在某些情况下,你可能也想要配置底层的开发服务器。(例如添加自定义的中间件到内部的 connect 应用中)为了实现这一点,你需要编写你自己的 插件 并使用 configureServer 函数。

示例:

export default defineConfig({
  server: {
    proxy: {
      // 字符串简写写法:http://localhost:5173/foo -> http://localhost:4567/foo
      '/foo': 'http://localhost:4567',
      // 带选项写法:http://localhost:5173/api/bar -> http://jsonplaceholder.typicode.com/bar
      '/api': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/api/, ''),
      },
      // 正则表达式写法:http://localhost:5173/fallback/ -> http://jsonplaceholder.typicode.com/
      '^/fallback/.*': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        rewrite: (path) => path.replace(/^\/fallback/, ''),
      },
      // 使用 proxy 实例
      '/api': {
        target: 'http://jsonplaceholder.typicode.com',
        changeOrigin: true,
        configure: (proxy, options) => {
          // proxy 是 'http-proxy' 的实例
        }
      },
      // 代理 websockets 或 socket.io 写法:ws://localhost:5173/socket.io -> ws://localhost:5174/socket.io
      '/socket.io': {
        target: 'ws://localhost:5174',
        ws: true,
      },
    },
  },
})

# server.cors

  • 类型:boolean | CorsOptions

为开发服务器配置 CORS。默认启用并允许任何源,传递一个 选项对象 来调整行为或设为 false表示禁用。

# server.headers

  • 类型:OutgoingHttpHeaders

指定服务器响应的 header。

# server.hmr

  • 类型:boolean | { protocol?: string, host?: string, port?: number, path?: string, timeout?: number, overlay?: boolean, clientPort?: number, server?: Server }

禁用或配置 HMR 连接(用于 HMR websocket 必须使用不同的 http 服务器地址的情况)。

设置 server.hmr.overlayfalse可以禁用开发服务器错误的屏蔽。

clientPort是一个高级选项,只在客户端的情况下覆盖端口,这允许你为 websocket 提供不同的端口,而并非在客户端代码中查找。如果需要在 dev-server 情况下使用 SSL 代理,这非常有用。

server.hmr.server被定义后,Vite 将会通过所提供的的服务器来处理 HMR 连接。如果不是在中间件模式下,Vite 将尝试通过已有服务器处理 HMR 连接。这在使用自签证书或想通过网络在某端口暴露 Vite 的情况下,非常有用。

查看 vite-setup-catalogue 一节获取更多实例。

NOTE

在默认配置下, 在 Vite 之前的反向代理应该支持代理 WebSocket。如果 Vite HMR 客户端连接 WebSocket 失败,该客户端将兜底为绕过反向代理、直接连接 WebSocket 到 Vite HMR 服务器:

Direct websocket connection fallback. Check out https://vitejs.dev/config/server-options.html#server-hmr to remove the previous connection error.

当该兜底策略偶然地可以被忽略时,这条报错将会出现在浏览器中。若要通过直接绕过反向代理来避免此错误,你可以:

  • 将反向代理配置为代理 WebSocket
  • 设置 server.strictPort = true 并设置 server.hmr.clientPort的值与 server.port相同
  • 设置 server.hmr.port为一个与 server.port 不同的值

# server.watch

  • 类型:object

传递给 chokidar 的文件系统监听器选项。

Vite 服务器默认会忽略对 .git/node_modules/目录的监听。如果你需要对 node_modules/内的包进行监听,你可以为 server.watch.ignored赋值一个取反的 glob 模式,例如:

export default defineConfig({
  server: {
    watch: {
      ignored: ['!**/node_modules/your-package-name/**'],
    },
  },
  // 被监听的包必须被排除在优化之外,
  // 以便它能出现在依赖关系图中并触发热更新。
  optimizeDeps: {
    exclude: ['your-package-name'],
  },
})

在 Windows Linux 子系统(WSL)上使用 Vite

当需要再 Windows Subsystem for Linux (WSL) 2 上运行 Vite 时,如果项目文件夹位于 Windows 文件系统中,你需要将此选项设置为 { usePolling: true }。这是由于 Windows 文件系统的 WSL2 限制 造成的。

要解决这一问题,你可以采取以下两种办法之一:

  • 推荐:使用 WSL2 应用来编辑你的文件

  • 同时我们推荐将你的项目移出 Windows 文件系统,从 WSL2 访问 Windows 文件系统非常慢。移除这一开销将大大提升性能表现。

  • 设置 { usePolling: true }

  • 注意 usePolling 会导致高 CPU 占用率

# server.middlewareMode

  • 类型:'ssr' | 'html'

以中间件模式创建 Vite 服务器。(不含 HTTP 服务器)

import express from 'express'
import { createServer as createViteServer } from 'vite'

async function createServer() {
  const app = express()

  // 以中间件模式创建 Vite 服务器
  const vite = await createViteServer({
    server: { middlewareMode: true },
    appType: 'custom', // 不引入 Vite 默认的 HTML 处理中间件
  })
  // 将 vite 的 connect 实例作中间件使用
  app.use(vite.middlewares)

  app.use('*', async (req, res) => {
    // 如果 `middlewareMode` 是 `'ssr'`,应在此为 `index.html` 提供服务.
    // 如果 `middlewareMode` 是 `'html'`,则此处无需手动服务 `index.html`
    // 因为 Vite 自会接管
  })
}

createServer()

# server.base

  • 类型:string | undefined

在 HTTP 请求中预留此文件夹,用于代理 Vite 作为子文件夹时使用。应该以 /字符开始。

# server.fs.strict

  • 类型:boolean
  • 默认:true(自 Vite 2.7 起默认启用)

限制为工作区 root 路径以外的文件的访问。

# server.fs.allow

  • 类型:string[]

限制哪些文件可以通过 /@fs/路径提供服务。当 server.fs.strict设置为 true 时,访问这个目录列表外的文件将会返回 403 结果。

Vite 将会搜索此根目录下潜在工作空间并作默认使用。一个有效的工作空间应符合以下几个条件,否则会默认以 项目 root 目录 作备选方案。

  • package.json中包含 workspaces字段
  • 包含以下几种文件之一
  • lerna.json
  • pnpm-workspace.yaml

接受一个路径作为自定义工作区的 root 目录。可以是绝对路径或是相对于 项目 root 目录 的相对路径。示例如下:

export default defineConfig({
  server: {
    fs: {
      // 允许为项目根目录的上一级提供服务
      allow: ['..']
    }
  }
})

server.fs.allow被设置时,工作区根目录的自动检索将被禁用。当需要扩展默认的行为时,你可以使用暴露出来的工具函数 searchForWorkspaceRoot

import { defineConfig, searchForWorkspaceRoot } from 'vite'

export default defineConfig({
  server: {
    fs: {
      allow: [
        // 搜索工作区的根目录
        searchForWorkspaceRoot(process.cwd()),
        // 自定义规则
        '/path/to/custom/allow'
      ]
    }
  }
})

# server.fs.deny

  • 类型:string[]
  • 默认:['.env', '.env.*', '*.{crt,pem}']

用于限制 Vite 开发服务器提供敏感文件的黑名单。

默认为 ['.env', '.env.*', '*.{pem,crt}']。这会比 server.fs.allow 选项的优先级更高。同时还支持 picomatch patterns

# server.origin

  • 类型:string

用于定义开发调试阶段生成资产的 origin。

export default defineConfig({
  server: {
    origin: 'http://127.0.0.1:8080',
  },
})
Last Updated: 3/8/2023, 8:47:01 AM