版面是一種 Astro 元件,用來建立可重複使用的 UI 結構,例如頁面模板。
我們習慣以「版面」稱呼在不同頁面共用的 Astro 元件,例如頁首、導覽列、頁尾這種 UI 元素。典型的 Astro 版面元件為 Astro、Markdown 或 MDX 頁面提供:
- 頁面殼層 (
<html>
、 <head>
和 <body>
標籤)
- 供頁面內容嵌入的插槽
<slot />
但其實版面元件沒什麼特別的!它們和其他 Astro 元件一樣,可以接受參數、匯入並使用其他元件,也能包含 UI 框架元件和客戶端腳本。甚至可當作局部 UI 模板,不需要提供整個頁面。
版面元件通常放在專案的 src/layouts
目錄,但這不是強制規定,可以自由選擇要放在哪裡。你甚至可以把它們跟頁面放在一起,只要在版面名稱加上 _
前綴即可。
版面對無法自訂頁面格式的 Markdown 和 MDX 頁面來說很實用。
Astro 特殊的 layout
frontmatter 屬性可以指定要把哪一個 .astro
元件當作頁面版面。
給 Markdown 或 MDX 頁面用的版面通常包含:
frontmatter
參數,能夠存取 Markdown 或 MDX 頁面的 frontmatter 和其他資料。
- 預設的
<slot />
,指名頁面的 Markdown/MDX 內容要在哪個位置渲染。
你可藉由 MarkdownLayoutProps
or MDXLayoutProps
設定版面的 Props
型別:
Markdown/MDX 版面能透過 Astro.props
存取下列資訊:
file
:檔案的絕對路徑 (例如 /home/user/projects/.../file.md
)。
url
:如果是頁面的話,即頁面網址(例如 /zh-tw/guides/markdown-content
)。
frontmatter
:Markdown 或 MDX 文件中的所有 frontmatter。
frontmatter.file
:同最上層的 file
屬性。
frontmatter.url
:同最上層的 url
屬性。
headings
:Markdown 或 MDX 文件中的標題(h1 -> h6
)列表,包含對應的 metadata。其型別為 { depth: number; slug: string; text: string }[]
。
- (Markdown 專屬)
rawContent()
:取得 Markdown 原始內容的函式,回傳值格式為字串。
- (Markdown 專屬)
compiledContent()
:取得 Markdown 編譯後內容的函式,回傳值格式為 HTML 字串。
舉例來說,Markdown 撰寫的部落格文章可以把下列 Astro.props
物件傳給它的版面:
需要傳遞資訊到 MDX 版面,但該版面不存在(或無法存在)frontmatter 時,可以匯入 <Layout />
元件,再像其他元件一樣透過參數傳遞給它:
如此一來,版面便能透過 Astro.props
存取數值,而 MDX 內容則會嵌入到包含 <slot />
的頁面中:
Astro 版面可以接收 .md
、.mdx
檔的 frontmatter
物件,以及從 .astro
檔傳入的任何具名參數。
以下範例中,版面的頁面標題會顯示從 frontmatter YAML title
屬性傳入的值,或從 Astro 元件傳入的 title
屬性:
版面元件不需要包含整頁 HTML 內容。可以將版面拆成更小的元件,並搭配使用版面元件建立更彈性的頁面模板。在不同版面共用程式碼時,這個模式十分實用。
舉例來說,BlogPostLayout.astro
元件可以為部落格文章的標題、日期,以及作者設定樣式。接著,在整個站台共用的 BaseLayout.astro
可以處理剩下的頁面模板,像導覽列、頁尾、SEO meta 標籤、全域樣式、字型等。你也可以從文章接收參數,再傳遞到其他版面,就像跟其他巢狀元件互動一樣。
Learn