Astro 語法
如果你知道 HTML,那麼你離撰寫 Astro 元件已經不遠了。
Astro 元件語法是 HTML 的超集合,寫過 HTML 或 JSX 的人會感到熟悉,而且它還支援匯入元件與 JavaScript 表達式。
類 JSX 表達式
標題為 類 JSX 表達式你可以在 Astro 元件內兩道圍欄(---
)中的 frontmatter 元件腳本定義本地 JavaScript 變數,接著使用類 JSX 表達式將這些變數注入到元件的 HTML 模板!
透過這種方式,frontmatter 可以計算並包含動態值。一旦包含其中,這些值便不再是互動式,之後也無法改變。Astro 元件這種模板只會在渲染階段執行一次而已。
詳見:Astro 和 JSX 的差異。
變數
標題為 變數本地變數可以透過大括弧(curly braces)加入 HTML:
動態屬性
標題為 動態屬性本地變數也能透過大括弧傳遞屬性值給 HTML 元素與元件:
HTML 屬性會轉換成字串,因此無法傳遞函式和物件給 HTML 元素。 舉例來說,在 Astro 元件裡,你不能指派 event handler 給 HTML 元素:
正確的做法是透過客戶端 JavaScript 建立 event handler,如同原生 JavaScript 寫法:
動態 HTML
標題為 動態 HTML類 JSX 函式可以使用本地變數動態產生 HTML 元素:
使用 JSX 邏輯運算子和三元表達式,Astro 能依照條件顯示 HTML。
動態標籤
標題為 動態標籤把變數設為 HTML 標籤名稱或要匯入的元件,便可使用動態標籤:
使用動態標籤時:
-
變數名稱首字要大寫。舉例來說:使用
Element
而不是element
。否則,Astro 會嘗試將變數名稱渲染成一般的 HTML 標籤。 -
不支援水合作用指令(hydration directive)。使用
client:*
水合作用指令時,Astro 需要事先知道哪個元件會被打包進正式版本,因此這種情況下不適用動態標籤。
Fragment
標題為 FragmentAstro 支援 <Fragment> </Fragment>
或簡寫 <> </>
。
有了 Fragment,我們在使用 set:*
指令 時便不需要額外包一層元素,如下所示:
Astro 和 JSX 的差異
標題為 Astro 和 JSX 的差異Astro 元件語法是 HTML 的超集合,寫過 HTML 或 JSX 的人會感到熟悉。但 .astro
檔案和 JSX 仍有些關鍵差異。
屬性
標題為 屬性所有屬性在 Astro 都用標準的 kebab-case
格式,而 JSX 則使用 camelCase
。class
對 Astro 來說也一樣,然而 React 卻不支援這點。
複數元素
標題為 複數元素與 JavaScript 或 JSX 不同,Astro 元件模板能渲染多個元素,不需要額外包一層 <div>
或 <>
。
註解
標題為 註解在 Astro 可以使用標準的 HTML 註解或 JavaScript 風格的註解。
HTML 風格的註解會出現在瀏覽器的 DOM,而 JS 風格的註解則不會。如果需要留下待辦註解或其他開發用的訊息,建議使用 JavaScript 風格的註解。