ポートフォリオ トップ Case Study — Real Site
実在サイトでの実作業(架空サンプルではありません)

Case Study — Site Replatform

デザインはそのまま。
中身を、保守できる静的サイトへ。

実際に公開・運用されているジュエリーブランドのサイトを、見た目を変えずに作り直した事例です。学習目的で Vue/Vite の SPA(クライアントサイドレンダリング)で作られていたサイトは、1ページのブランドLPに対して構成が重く、所有者が自分で保守できない状態でした。デザインを1px単位で踏襲したまま、中身を完全な静的HTMLへ置き換え、表示崩れ・SEO・速度・保守性・ホスティングをまとめて立て直しました。

見た目は意図的に同一です。だからこの事例の主役は「変わって見えるもの」ではなく、計測できる中身の差(Lighthouse スコア・CLS・SEO・構造)です。数値はすべて実在サイトの実測値です。

Overview

何をした事例か

対象は、猫モチーフのジュエリーブランドの1ページ構成のサイト。初期HTMLは <div id="app"></div> の空シェルで、本文はすべて JavaScript が描画する SPA(CSR) でした。軽量ではあったものの、本文がHTMLに存在しないため 検索エンジンやSNSのクローラが内容を読めず、見出し構造や lang・OGP などの基本も欠けていました。そして何より、1ページのLPにビルドを伴うSPAという過剰な構成のため、所有者がもう自分で更新できなくなっていました。

方針は「デザインは1pxも変えない/中身を作り直す」。リニューアルというと見た目を一新しがちですが、このブランドの世界観は完成していたので、あえて見た目を完全保存し、土台だけを現代的な静的サイトへ載せ替えました。作業は2段階に分け、まず「小さな修正だけでどこまで改善するか」を実演し、続いて「全面再構築でどこまで到達できるか」を示しています。

現状(Before)

Vue/Vite の SPA。本文がJS依存・h1なし・lang誤り・OGPなし・robots/sitemap不在。表示時に画像がガタつく(CLS 0.95)。所有者が保守不能。

Stage 1:小さな修正

Vue本体に触れず、<head> と静的ファイル追加だけで改善。lang・description・OGP・favicon・robots.txt・sitemap を整備。SEO 91→100。

Stage 2:静的化(本命)

Astro(SSG)で完全な静的HTMLへ再構築。CSR撤廃・h1新設・構造化データ・画像最適化で速度と保守性を確立。Performance 62→97、CLS→0。

Before / After

変わったのは「見えない部分」

見た目は据え置き。下のリストはすべて、ユーザーには見えにくいが集客・保守・信頼に効く部分です。

Before

Vue / Vite の SPA(CSR)

  • 本文がJS依存。SNS・一部クローラが内容を読めない
  • <html lang="en">(日本語サイトなのに英語指定)
  • h1 が 0 個・見出しが h3 から始まる
  • meta description / OGP / Twitter Card なし
  • robots.txt・sitemap.xml 実質不在/soft-404
  • 画像に width/height がなく表示がガタつく(CLS 0.95)
  • 1ページLPにSPA=所有者が自分で保守できない
After

Astro による完全な静的HTML(SSG)

  • 本文がHTMLに存在=検索・SNS・クローラすべて対応
  • lang="ja"+セマンティックな見出し構造へ
  • h1 を新設し h1→h2→h3 の階層に整理
  • description・OGP・Twitter Card・canonical・構造化データ(JSON-LD)
  • robots.txt+sitemap を静的内包/正しい404
  • 全画像に width/height を指定し CLS を 0 に
  • 素のCSS(依存最小)で所有者でも手を入れやすい構成

Measured — Real Numbers

計測できる改善(実測値)

Lighthouse(モバイル)での実測。Before=公開中だった旧サイト、After=本番相当ビルドのローカル計測(2026-06-14)。

Performance

6297

CSR撤廃・画像最適化で大幅改善

Accessibility

92100

lang・見出し・alt・コントラスト

Best Practices

100

据え置きで満点を維持

SEO

91100

静的HTML・構造化・sitemap

3段階のスコア推移(Lighthouse モバイル)
カテゴリ 現状(Vue SPA) Stage 1(小修正) Stage 2(静的)
Performance626797
Accessibility9292100
Best Practices100100100
SEO91100100
主要指標(Core Web Vitals 関連)
指標BeforeAfter
FCP(初回描画)2.1s1.5s
LCP(主要描画)3.8s2.5s
CLS(表示の安定性)0.950(全画像に width/height)
TBT(操作ブロック)0ms0ms

What changed

改修内容(Before → After 対応表)

見た目を変えずに、一つひとつの変更が「検索・共有・保守・体感速度」にどう効くかをセットで設計しました。

課題ごとの改修と効果
課題改修(After で行ったこと)効果
本文がJSでしか出ない(CSR)Astro(SSG) で本文を静的HTML化検索エンジン・SNSのクローラが確実に内容を読める
lang が en・h1 が無いlang="ja"+h1新設で h1→h2→h3 に読み上げ・検索の文脈理解が正しくなる
OGP / Twitter Card 無しOGP・Twitter Card・canonical・JSON-LD を整備SNS共有でサムネと説明が出て、クリックされやすい
robots.txt・sitemap 不在robots.txt+sitemap を静的内包検索エンジンが巡回・登録しやすくなる
表示がガタつく(CLS 0.95)全画像に width/height を指定読み込み中のレイアウト崩れが消える(CLS 0)
画像が単一形式<picture> で avif→webp→jpg 出し分け対応ブラウザで軽い形式を配信し体感が速い
未使用フォントを2重読込重複@importを解消し使用フォントのみに描画ブロックを減らし初期表示を軽く
淡いオリーブ文字が低コントラスト文字色を #ABAC70#6f7038(AA合格)に読みやすさと配慮を確保(色味の印象は維持)
1ページLPにSPA(保守不能)素のCSSの静的サイトへ(依存最小)所有者でも更新でき、長く維持できる

Stack & Hosting

技術スタックとホスティング移行

再構築は Astro 6(SSG)素のCSS(Tailwind 等のフレームワーク不使用で依存を最小化し、保守を容易に)。画像はビルド済みの avif・webp・jpg を <picture> で出し分けています。サイトマップは @astrojs/sitemap で自動生成。

ホスティングも併せて見直し、Firebase Hosting+Cloudflare から GitHub Pages へ移行しました。GitHub へ push すると GitHub Actions が自動でビルド・デプロイする構成です。独自ドメインはDNSのAレコードを GitHub Pages に向け替え、メール(MXレコード)は一切変更せず保全。HTTPS証明書は GitHub Pages が自動発行します。

# Astro 6 / SSG # 素のCSS(依存最小) # picture avif/webp/jpg # JSON-LD 構造化データ # GitHub Pages / Actions # DNS切替(MX保全)

Design — Preserved

デザインは Before / After で同一

下はリニューアル後の実画面です。ブランドの世界観はそのまま。変えたのは中身だけ、という事例の主旨を示すために掲載しています。

リニューアル後のブランドビジュアル(ヒーロー)。デザインは改修前と同一。
ヒーロー:ブランドビジュアル(改修前後で同一)
商品写真:蝶モチーフのネックレス。
COLLECTION の商品写真(avif/webp/jpg を出し分け)
商品写真:三日月に座る猫モチーフのネックレス。
同上。width/height 指定で CLS を 0 に

「見た目はそのまま、中身だけ作り直す」
— 実在サイトで実際に行った作業です。

架空サンプルではなく、公開・運用中のサイトでの実作業の記録です。公開中のサイトをご覧ください。