TanStack Router 文件命名约定

基于文件的路由要求你遵循一些简单的文件命名约定,以确保正确生成路由。这些约定所启用的概念在 路由树与嵌套 指南中有详细介绍。

特性 (Feature) 描述 (Description)
__root.tsx 根路由文件必须命名为 __root.tsx,并且必须放置在配置的 routesDirectory 的根目录下。
. 分隔符 路由可以使用 . 字符来表示嵌套路由。例如,blog.post 将生成为 blog 的子路由。
$ 标记 带有 $ 标记的路由片段是参数化的,并将从 URL 路径名中提取值作为路由 param(参数)。
_ 前缀 带有 _ 前缀的路由片段被视为无路径布局路由,在将子路由与 URL 路径名匹配时不会使用它。
_ 后缀 带有 _ 后缀的路由片段将该路由排除在任何父路由的嵌套之外(即非嵌套路由)。
- 前缀 带有 - 前缀的文件和文件夹将从路由树中排除 。它们不会被添加到 routeTree.gen.ts 文件中,可用于在路由文件夹中共存逻辑代码。
(folder) 文件夹名模式 匹配此模式的文件夹被视为路由组,防止该文件夹包含在路由的 URL 路径中。
[x] 转义 方括号用于转义文件名中具有路由含义的特殊字符。例如,script[.]js.tsx 变为 /script.jsapi[.]v1.tsx 变为 /api.v1
index 标记 index 标记结尾(在任何文件扩展名之前)的路由片段,当 URL 路径名精确匹配父路由时,将匹配父路由。这可以通过 indexToken 配置选项进行配置,参见 [suspicious link removed]。
.route.tsx 文件类型 当使用目录组织路由时,route 后缀可用于在目录路径处创建路由文件。例如,blog.post.route.tsxblog/post/route.tsx 可用作 /blog/post 路由的路由文件。这可以通过 routeToken 配置选项进行配置,参见 [suspicious link removed]。

💡 记住: 项目的文件命名约定可能会受到所配置的 [suspicious link removed] 的影响。

!NOTE

要转义尾随下划线(例如 /posts[_].tsx),需要使用升级后的 非嵌套路由。

动态路径参数 (Dynamic Path Params)

动态路径参数可用于扁平路由和目录路由,以创建可以匹配 URL 路径动态片段的路由。动态路径参数由文件名中的 $ 字符表示:

文件名 (Filename) 路由路径 (Route Path) 组件输出 (Component Output)
... ... ...
ʦ posts.$postId.tsx /posts/$postId <Root><Posts><Post>

我们将在 路径参数 指南中了解更多关于动态路径参数的信息。

无路径路由 (Pathless Routes)

无路径路由用逻辑或组件包裹子路由,而不需要 URL 路径。无路径路由由文件名中的 _ 字符表示:

文件名 (Filename) 路由路径 (Route Path) 组件输出 (Component Output)
ʦ _app.tsx
ʦ _app.a.tsx /a <Root><App><A>
ʦ _app.b.tsx /b <Root><App><B>

要了解更多关于无路径路由的信息,请参阅 路由概念 - 无路径路由 指南。

相关推荐
夏幻灵14 小时前
HTML5里最常用的十大标签
前端·html·html5
Mr Xu_14 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝14 小时前
RBAC前端架构-01:项目初始化
前端·架构
程序员agions15 小时前
2026年,微前端终于“死“了
前端·状态模式
万岳科技系统开发15 小时前
食堂采购系统源码库存扣减算法与并发控制实现详解
java·前端·数据库·算法
程序员猫哥_15 小时前
HTML 生成网页工具推荐:从手写代码到 AI 自动生成网页的进化路径
前端·人工智能·html
龙飞0515 小时前
Systemd -systemctl - journalctl 速查表:服务管理 + 日志排障
linux·运维·前端·chrome·systemctl·journalctl
我爱加班、、15 小时前
Websocket能携带token过去后端吗
前端·后端·websocket
AAA阿giao15 小时前
从零拆解一个 React + TypeScript 的 TodoList:模块化、数据流与工程实践
前端·react.js·ui·typescript·前端框架
杨超越luckly15 小时前
HTML应用指南:利用GET请求获取中国500强企业名单,揭秘企业增长、分化与转型的新常态
前端·数据库·html·可视化·中国500强