server.routes

  • 类型: Object
  • 默认值: 根据文件约定自动生成的服务端路由规则,每个入口生成一条路由规则,入口名称等于路由路径。

该配置选项只作用于服务端路由,可以自定义应用入口的访问路由。

自定义访问路由

对象的 key 为当前应用的入口名, 值可以是 string | Array<string>

当值类型为 string 时,当前值即表示访问该入口的路由名称。

modern.config.ts
export default defineConfig({
  server: {
    routes: {
      // 默认路由为 /entryName1,自定义后为 /p/test1
      entryName1: '/p/test1'
      // 支持动态服务端路由配置
      entryName2: '/detail/:id'
    }
  }
});

也可以通过 Array<string> 为入口设置多个访问路由:

modern.config.ts
export default defineConfig({
  server: {
    routes: {
      'page-a': [`/a`, '/b'],
    },
  },
});

此时,通过 /a/b 两个路由都可以访问到 page-a 入口。

执行 dev 命令后,可以在 dist/route.json 中查看入口 page-a 存在两条路由记录:

{
  "routes": [
    {
      "urlPath": "/a",
      "entryName": "page-a",
      "entryPath": "html/page-a/index.html",
      "isSPA": true,
      "isSSR": false
    },
    {
      "urlPath": "/b",
      "entryName": "page-a",
      "entryPath": "html/page-a/index.html",
      "isSPA": true,
      "isSSR": false
    }
  ]
}

自定义响应头

可以通过配置入口的 resHeaders 设置响应头:

modern.config.ts
export default defineConfig({
  server: {
    routes: {
      'page-a': {
        route: ['/a', '/b'],
        resHeaders: {
          'x-modern-test': '1',
        },
      },
    },
  },
});
NOTE

这一配置在生产环境与开发环境都生效,可以根据 NODE_ENV 区分环境设置不同的响应头。但如果你只需要在开发环境设置响应头,推荐使用 tools.devServer.headers