本文へスキップ
Acecore

VitePress から Starlight へ ― ドキュメントサイトのフレームワーク統一

by Gui
目次
VitePress から Starlight へ ― ドキュメントサイトのフレームワーク統一

VitePress で作ったドキュメントサイトを、Astro + Starlight に移行する手順をまとめます。メインサイトが Astro で動いている場合、ドキュメントも Starlight に統一すると運用がシンプルになります。Mermaid 図表の CDN 移行についても紹介します。

なぜフレームワークを統一するのか

メインサイトとドキュメントサイトで異なるフレームワークを使っていると、以下の問題が発生します:

  • 学習コストの二重化:VitePress と Astro の両方の仕様を把握する必要がある
  • 依存の分散:npm パッケージの更新を2系統で管理
  • 設定の一貫性:ESLint、Prettier、デプロイ設定などを個別に維持

Astro + Starlight に統一することで、設定ファイルのパターン化やトラブルシューティングの知見を共有できるようになります。

VitePress から Starlight への移行手順

1. プロジェクト構造の変換

VitePress はドキュメントを docs/ ディレクトリに、Starlight は src/content/docs/ に配置します。

# 変更前(VitePress)
docs/
  pages/
    index.md
    business-overview.md
    market-analysis.md

# 変更後(Starlight)
src/
  content/
    docs/
      index.md
      business-overview.md
      market-analysis.md

2. フロントマターの調整

VitePress と Starlight ではフロントマターの形式が微妙に異なります。VitePress の sidebar 設定をフロントマターの sidebar フィールドに移行しました。

# Starlight のフロントマター
---
title: 事業概要
sidebar:
  order: 1
---

3. astro.config.mjs の設定

import { defineConfig } from 'astro/config'
import starlight from '@astrojs/starlight'

export default defineConfig({
  integrations: [
    starlight({
      title: 'Acecore 事業計画',
      defaultLocale: 'ja',
      sidebar: [
        {
          label: '事業計画',
          autogenerate: { directory: '/' },
        },
      ],
    }),
  ],
})

4. UnoCSS の削除

VitePress 環境では UnoCSS でカスタムスタイルを適用していましたが、Starlight には十分なデフォルトスタイルが組み込まれています。uno.config.ts と関連パッケージを削除し、依存をスリム化しました。

Mermaid 図表の CDN 移行

事業計画ドキュメントにはフローチャートや組織図を Mermaid で記述しています。VitePress ではプラグイン(vitepress-plugin-mermaid)で Mermaid を統合していましたが、Starlight にはそのようなプラグインがありません。

そこで、Mermaid をブラウザサイドで CDN から読み込む方式に切り替えました。

実装方法

Starlight のカスタムヘッドに Mermaid の CDN スクリプトを追加します。

// astro.config.mjs
starlight({
  head: [
    {
      tag: 'script',
      attrs: { type: 'module' },
      content: `
        import mermaid from 'https://cdn.jsdelivr.net/npm/mermaid@11/dist/mermaid.esm.min.mjs'
        mermaid.initialize({ startOnLoad: true })
      `,
    },
  ],
})

Markdown 内では通常の Mermaid 記法がそのまま使えます:

```mermaid
graph TD
    A[事業計画] --> B[市場分析]
    A --> C[販売戦略]
    A --> D[財務計画]
```

CDN 方式のメリット

  • ビルド依存ゼロ:npm パッケージとしての Mermaid が不要
  • 常に最新バージョン:CDN から最新版を取得
  • SSR 不要:ブラウザで描画するためビルド時間に影響しない

移行結果

項目BeforeAfter
フレームワークVitePress 1.xAstro 6 + Starlight
CSSUnoCSSStarlight 組み込み
Mermaidvitepress-plugin-mermaidCDN(jsdelivr)
ビルド出力先docs/.vitepress/distdist
デプロイ先Cloudflare PagesCloudflare Pages(変更なし)

フレームワークの統一により、astro.config.mjs の設定パターンやデプロイ設定を複数プロジェクト間で共有できるようになります。

まとめ

フレームワーク統一は「今すぐ必要」ではなくても、運用が長くなるほど効いてくる施策です。VitePress から Starlight への移行自体は数時間で完了でき、Mermaid の CDN 化はむしろプラグイン管理からの解放というメリットがあります。複数プロジェクトを運用している方は、技術スタックの統一を検討してみてください。

移行の流れ

現状分析

VitePress + UnoCSS の構成を整理。

Starlight 導入

Astro + Starlight でプロジェクトを再構成。

コンテンツ移行

Markdown ファイルの配置とフロントマターを調整。

Mermaid CDN 化

プラグイン依存を排除し CDN で図表を描画。

移行前後の比較

VitePress + UnoCSS

  • Vue ベースの SSG
  • UnoCSS でスタイリング
  • Mermaid はプラグインで動作
  • Astro プロジェクトと技術スタックが別

Astro + Starlight

  • Astro ベースの SSG
  • Starlight 組み込みのスタイリング
  • Mermaid は CDN で動作
  • メインサイトとフレームワーク統一
よくある質問
VitePress から Starlight に移行するメリットは何ですか?
メインサイトが Astro の場合、フレームワークを統一できるため学習コスト・依存管理・設定の一貫性が向上します。ビルドパイプラインも一本化できます。
Mermaid の図表はどうやって表示しますか?
プラグイン依存をやめ、CDN(jsdelivr)経由で Mermaid を読み込む方式に切り替えました。ビルド依存がゼロになり、図表のレンダリングも安定します。
移行作業にはどのくらいの手間がかかりますか?
主な作業はディレクトリ構造の変換(docs/ → src/content/docs/)とフロントマターの調整です。コンテンツ自体は Markdown なのでそのまま使えるため、比較的短時間で完了します。
G

Gui

Acecore 代表。システム開発・Web制作・インフラ運用からIT教育まで幅広く手がけるエンジニア。 技術で人と組織の課題を解きほぐすのが好き。

システム開発 Web制作 インフラ運用 IT教育

開発・Web制作のご相談はお気軽に

要件整理からデザイン・実装・運用まで、ワンストップでサポートします。

関連記事

記事を検索