zfb

Type to search...

to open search from anywhere

meta export

作成2026年6月1日Takeshi Takatsudo

meta エクスポートでページごとの head メタデータを宣言します。

パターン

すべてのページモジュールは、ページの <head> データ(タイトル、説明、Open Graph タグ、正規 URL など)を記述する meta 定数(または同じレコードを返す async 関数)をエクスポートできます。レンダラはこのエクスポートを RenderHost::get_export 経由で読み取り、ページレイアウトの <head> ブロックにマージします。

export const meta = {
  title: "Blog — My Site",
  description: "Latest writing on web development.",
  canonical: "https://example.com/blog",
  og: {
    image: "/og/blog.png",
    type: "website",
  },
};

export default function BlogPage() {
  return <article>{/* ... */}</article>;
}

meta を計算するためにコレクションや async ソースからのデータが必要な場合(例: CMS フィールドから導出する OG 画像)は、meta を async 関数としてエクスポートします。レンダラはページシェルをレンダリングする前にそれを await します。

export async function meta() {
  const post = getCollection("blog")[0];
  return {
    title: post.data.title,
    og: { image: `/og/${post.slug}.png` },
  };
}

サポートされるキー

レンダラは meta を寛容なバッグとして扱いますが、ページレイアウトが参照するサポート対象のサブセットは以下のキーです。

  • title?: string — このページについてレイアウトのデフォルトを上書きします。
  • description?: string<meta name="description"> タグに使われ、OG のフォールバックにもなります。
  • canonical?: string<link rel="canonical"> 用の絶対 URL。
  • og?: { title?, description?, image?, type?, url? } — Open Graph タグ。欠けているフィールドは、意味が通る範囲でトップレベルの title / description にフォールバックします。
  • twitter?: { card?, site?, creator?, image? } — Twitter Card タグ。
  • layout?: string — ページレイアウトコンポーネントのモジュール specifier(相対パスまたはベア specifier)。指定がない場合はプロジェクトのデフォルトレイアウトが使われます。

未知のキーはそのまま素通りするため、プラグインやカスタムレイアウトコンポーネント向けの構造化データを格納しておけます。

Revision History