布局
布局是特殊的 Astro 组件,可用于创建可重用的页面模板。
我们通常将“布局”用于提供共享页面的常用 UI 元素(如标题、导航栏和页脚)的 Astro 组件。典型的 Astro 布局组件为 Astro、Markdown 或 MDX 页面提供:
- 一个 页面外壳(
<html>
、<head>
和<body>
标签) - 一个
<slot />
来指定单个页面内容应该被注入的位置。
但是,布局组件没有什么特别的!它们可以像任何其他 Astro 组件一样接受 props和导入和使用其他组件。它们可以包含UI 框架组件和客户端脚本。它们甚至不必提供完整的页面外壳,而是可以用作部分 UI 模板。
然而,如果布局组件确实包含页面外壳,那么它的 <html>
元素必须是该组件中所有其他元素的父元素。
布局组件通常放置在项目中的 src/layouts
目录中,但这不是必须的。你可以选择将它们放置在项目中的任何位置。你甚至可以通过在布局组件名称前面加上“_”将布局组件与页面放在同一个文件夹中。
示例布局
段落标题 示例布局---import BaseHead from '../components/BaseHead.astro';import Footer from '../components/Footer.astro';const { title } = Astro.props;---<html lang="en"> <head> <meta charset="utf-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <BaseHead title={title}/> </head> <body> <nav> <a href="#">主页</a> <a href="#">文章</a> <a href="#">联系</a> </nav> <h1>{title}</h1> <article> <slot /> <!-- 你的内容会被插入到这里 --> </article> <Footer /> </body> <style> h1 { font-size: 2rem; } </style></html>