{
  "url": "https://unifast.dev/ja/docs/guides/mdx/",
  "locale": "ja",
  "title": "MDX を使う",
  "description": "unifast で MDX をコンパイルし、Markdown 内で JSX 式や import 文を利用して、React などの JSX ランタイムでレンダリングします。",
  "section": "guides",
  "body": "MDX を使うと、Markdown の中で JSX 式や import 文を利用できます。unifast は MDX を JavaScript モジュールにコンパイルし、React などの JSX ランタイムでレンダリングできます。\n\n### インストール\n\n### 基本的な使い方\n\n```ts\n\nconst source = `\n# Hello\n\nexport const meta = { title: \"My Page\" };\n`;\n\nconst result = compile(source, { inputKind: \"mdx\" });\n// result.output is a JavaScript module string\n```\n\n### MDX のしくみ\n\nMDX は Markdown を次の 2 つの機能で拡張します。\n\n1. **JSX 式** - コンテンツ内にインラインでコンポーネントを使えます。\n2. **ESM の import/export** - コンポーネントのインポートとメタデータのエクスポートが可能です。\n\nコンパイラは次の手順で MDX を処理します。\n\n```\nMDX source\n  → Parse (Markdown + JSX + ESM)\n  → MdAst with JSX/ESM nodes\n  → Lower to HAst\n  → Emit as JavaScript module\n```\n\n出力は、コンポーネントを注入するための `components` プロパティを受け取るデフォルトエクスポート関数を持つ JavaScript モジュールです。\n\n### React と組み合わせて使う\n\n```ts\n\nconst source = `# Hello\\n\\nThis is **MDX**.`;\n\nconst result = compile(source, { inputKind: \"mdx\" });\nconst Component = compileToReact(result);\n\n// Render in your React app\n\n```\n\n### MDX での Frontmatter\n\nMDX と frontmatter プラグインを組み合わせれば、メタデータを抽出できます。\n\n```ts\n\nconst source = `---\ntitle: My Article\nauthor: Jane\n---\n\n# {frontmatter.title}\n\nWritten by {frontmatter.author}.\n`;\n\nconst result = compile(source, {\n  inputKind: \"mdx\",\n  plugins: [frontmatter()],\n});\n\nconsole.log(result.frontmatter);\n// { title: \"My Article\", author: \"Jane\" }\n```\n\n### 関連項目\n\n- [compile()](/docs/packages/node/compile) - 完全な API リファレンス\n- [React インテグレーション](/docs/guides/react) - React で MDX をレンダリングする",
  "alternates": [
    {
      "locale": "en",
      "url": "https://unifast.dev/docs/guides/mdx/",
      "api": "https://unifast.dev//api/docs/guides/mdx.json"
    },
    {
      "locale": "ja",
      "url": "https://unifast.dev/ja/docs/guides/mdx/",
      "api": "https://unifast.dev//api/ja/docs/guides/mdx.json"
    },
    {
      "locale": "zh-CN",
      "url": "https://unifast.dev/zh-CN/docs/guides/mdx/",
      "api": "https://unifast.dev//api/zh-CN/docs/guides/mdx.json"
    },
    {
      "locale": "zh-TW",
      "url": "https://unifast.dev/zh-TW/docs/guides/mdx/",
      "api": "https://unifast.dev//api/zh-TW/docs/guides/mdx.json"
    },
    {
      "locale": "ko",
      "url": "https://unifast.dev/ko/docs/guides/mdx/",
      "api": "https://unifast.dev//api/ko/docs/guides/mdx.json"
    },
    {
      "locale": "fr",
      "url": "https://unifast.dev/fr/docs/guides/mdx/",
      "api": "https://unifast.dev//api/fr/docs/guides/mdx.json"
    },
    {
      "locale": "it",
      "url": "https://unifast.dev/it/docs/guides/mdx/",
      "api": "https://unifast.dev//api/it/docs/guides/mdx.json"
    },
    {
      "locale": "es",
      "url": "https://unifast.dev/es/docs/guides/mdx/",
      "api": "https://unifast.dev//api/es/docs/guides/mdx.json"
    },
    {
      "locale": "pt-BR",
      "url": "https://unifast.dev/pt-BR/docs/guides/mdx/",
      "api": "https://unifast.dev//api/pt-BR/docs/guides/mdx.json"
    },
    {
      "locale": "de",
      "url": "https://unifast.dev/de/docs/guides/mdx/",
      "api": "https://unifast.dev//api/de/docs/guides/mdx.json"
    },
    {
      "locale": "ru",
      "url": "https://unifast.dev/ru/docs/guides/mdx/",
      "api": "https://unifast.dev//api/ru/docs/guides/mdx.json"
    },
    {
      "locale": "hi",
      "url": "https://unifast.dev/hi/docs/guides/mdx/",
      "api": "https://unifast.dev//api/hi/docs/guides/mdx.json"
    },
    {
      "locale": "id",
      "url": "https://unifast.dev/id/docs/guides/mdx/",
      "api": "https://unifast.dev//api/id/docs/guides/mdx.json"
    },
    {
      "locale": "tr",
      "url": "https://unifast.dev/tr/docs/guides/mdx/",
      "api": "https://unifast.dev//api/tr/docs/guides/mdx.json"
    },
    {
      "locale": "vi",
      "url": "https://unifast.dev/vi/docs/guides/mdx/",
      "api": "https://unifast.dev//api/vi/docs/guides/mdx.json"
    }
  ]
}
