路由
Astro 使用基于文件的路由,它根据项目 src/pages
目录中的文件结构来生成你的构建链接。
页面之间的导航
Astro 使用标准 HTML <a>
元素 在路由之间导航。 没有提供特定框架的 <Link>
组件。
静态路由
src/pages
目录中的 .astro
页面组件以及 Markdown 和 MDX 文件(.md
,.mdx
)将自动作为网站页面。每个页面的路由对应于它在 src/pages/
目录中的路径和文件名。
Astro 项目没有单独的路由配置!当你在 src/pages
目录新增文件时,会自动生成一个新的路由。在静态生成中,你可以使用 build.format
配置项自定义文件输出格式。
动态路由
Astro 页面文件可以在其文件名中指定动态路由参数以生成多个匹配页面。
例如,src/pages/authors/[author].astro
可以为你博客上的每一位作者生成一个简介页面,而 author
将作为一个你可以从页面内部访问的 参数 。
在 Astro 默认的静态输出模式中,这些页面是在构建时生成的,因此你必须预设对应文件的 author
列表。而在 SSR 模式下,将根据请求为任何匹配的路由生成一个页面。
静态 (SSG) 模式
因为必须在构建时确定所有路由,所以动态路由必须导出一个 getStaticPaths()
,它返回一个具有 params
属性的对象数组。数组中的每一个对象都会生成相应的路由。
[dog].astro
在其文件名中定义一个 dog
参数,则 getStaticPaths()
返回的这些对象的 params
中必须包含 dog
。
然后页面可以使用 Astro.params
访问该参数。
这将生成三个页面: /dogs/clifford
、/dogs/rover
和 /dogs/spot
,每个页面显示相应的狗名。
文件名可以包含多个参数,这些参数必须都包含在 getStaticPaths()
的 params
对象中:
这将生成 /en-v1/info
和 /fr-v2/info
路由。
参数也可以包含在路径的单独部分中。例如, src/pages/[lang]/[version]/info.astro
文件与上面相同的 getStaticPaths()
将生成路由 /en/v1/info
和 /fr/v2/info
。
📚 了解更多关于 getStaticPaths()
。
剩余参数
如果你的URL路由需要更加灵活,你可以在 .astro
文件名中使用一个 剩余参数([...path]
),去匹配任何深度的文件路径。
这将生成 /sequences/one/two/three
、 /sequences/four
和 /sequences
。(将剩余参数设置为 undefined
允许它匹配顶级页面。)
剩余参数可以与 其他命名参数 一起使用。例如, GitHub 的文件查看器可以用以下动态路由表示:
在这个示例中,对 /withastro/astro/tree/main/docs/public/favicon.svg
的请求将拆分为以下命名参数:
示例:多级动态页面
在下面的示例中, 剩余参数([...slug]
)和 getStaticPaths()
的 props
为不同深度的 slug 生成页面。
服务器(SSR)模式
在 SSR 模式下,动态路由以相同的方式定义:在文件名中包含 [param]
或 [...path]
以匹配任意字符串或路径。但是由于不再提前构建路由,页面将提供给任何匹配的路由。由于这些路由不是“静态”的,因此不应使用 getStaticPaths
。
该页面将为任意的 resource
和 id
提供服务: resources/users/1
、 resources/colors/blue
等。
修改 [...slug]
示例用于SSR
由于 SSR 页面无法使用 getStaticPaths()
,因此无法接收 props。可以通过在对象中查找 slug
参数的值,将 前面的示例 调整为 SSR 模式。如果路由位于根目录(“/”),则 slug 参数为 undefined
。如果对象中不存在该值,将重定向到 404 页面。
重定向
有时你需要为你的读者重定向到一个新的页面,可能由于你的网站结构发生了永久性的变动,又或者是作为响应动作(比如从登录到身份验证的过程)。
你可以在你的 Astro 配置中定义规则来将用户 永久重定向到已移动的页面。或者,根据用户的使用情况,动态地将用户重定向。
配置重定向
添加于:astro@2.9.0
在你的 Astro 配置中,你可以使用 redirects
值来指定永久重定向的映射关系。对于大多数重定向而言,通常是将旧路由映射到新路由:
这些重定向遵循与基于文件路由相同的规则。只要新旧路由都包含相同的参数,就可以使用动态路由,例如:
使用 SSR(服务器端渲染)或者静态适配器,你还可以将对象作为值提供,除了新的 destination
端点指向之外,还可以指定 status
状态码:
在运行 astro build
时,默认情况下,Astro 将输出带有 meta refresh 标签的 HTML 文件。支持的适配器将会使用托管服务器的配置文件写入重定向信息。
状态码默认为 301
。如果构建为 HTML 文件,则服务器不会使用状态码。
动态重定向
在全局的 Astro
对象上,Astro.redirect
方法允许你动态地重定向到另一个页面。例如,你可以在检查用户是否已登录(通过从 Cookie 中获取其会话)之后执行此操作。
路由优先级顺序
多个路由可以匹配相同的 URL 路径。例如下面的每个路由都会匹配 /posts/create
。
目录src/pages/
目录posts/
- create.astro
- [pid].astro
- […slug].astro
Astro 需要知道哪个路由应该被用来建立页面。为了做到这一点,它根据以下规则对它们进行排序。
- 没有路径参数的静态路由将优先于所有其他路由
- 使用命名参数的动态路由优先于使用剩余参数的动态路由
- 剩余参数的优先级最低
- 以上规则优先级相同,则按字母顺序排序
鉴于上面的示例,下面用几个例子,说明这些规则如何匹配请求的URL与用于建立HTML的路由。
pages/posts/create.astro
- 将构建/posts/create
pages/posts/[pid].astro
- 将构建/posts/1
、/posts/abc
等,但不包括/posts/create
pages/posts/[...slug].astro
- 将构建/posts/1/2
、/posts/a/b/c
等,但不包括/posts/create
、/posts/1
、/posts/abc
分页
Astro 支持内置分页,用于需要分割成多个页面的大量数据。Astro 会生成常见的分页属性,包括上一页/下一页链接、总页数等。
分页的路由名应该使用与标准动态路由一样的 [bracket]
语法。例如,文件名 /astronauts/[page].astro
将生成 /astronauts/1
、/astronauts/2
等路由,其中 [page]
是生成的页码。
你可以用 paginate()
函数根据数组值生成这些页面:
将生成以下两个页面,每页 2 项:
/astronauts/1
- 第一页显示“Neil Armstrong”和“Buzz Aldrin”/astronauts/2
- 第二页显示“Sally Ride”和“John Glenn”
page
属性
当你使用 paginate()
函数时,每个页面将通过 page
传递数据。page
有很多有用的属性,下面列出最为重要的:
- page.data - 数组,包含你传递给
paginate()
函数的页面数据片段 - page.url.next - 下一个页面的链接
- page.url.prev - 上一个页面的链接
完整的 API 参考
嵌套分页
分页的一个更高级的用例是嵌套分页。当分页与其他动态路由参数相结合时,你可以使用嵌套式分页和一些属性或标签来将分页进行分类。
例如,如果你想通过一些标签来分组你的分页的 Markdown 帖子,你可以通过创建一个 /src/pages/[tag]/[page].astro
的页面来使用嵌套分页,该页面将匹配以下链接。
/red/1
(tag=red)/red/2
(tag=red)/blue/1
(tag=blue)/green/1
(tag=green)
嵌套分页的工作原理是使用 getStaticPaths()
返回每个分组的 paginate()
结果数组。
在下面的例子中,我们将实现嵌套分页来建立上面列出的URL。
排除页面
你可以通过在文件名前加上下划线(_
)来排除页面或目录的构建。带有 _
前缀的文件不会被路由识别,也不会被放入 dist/
目录。
你可以使用它来暂时禁用页面,并将测试、工具函数和组件放在与其相关页面同一个文件夹中。
在这个例子中,只有 src/pages/index.astro
和 src/pages/posts/post1.md
将被构建为页面路由和 HTML 文件。
目录src/pages/
目录_hidden-directory/
- page1.md
- page2.md
- _hidden-page.astro
- index.astro
目录posts/
- _SomeComponent.astro
- _utils.js
- post1.md