seo-best-practices
SEO patterns, conventions, and audit for web applications. Use when implementing meta tags, structured data, Core Web Vitals, sitemaps, Open Graph, auditing SEO, or optimizing pages for search engines. Triggers on "audit SEO", "check SEO", "review SEO", or tasks involving search optimization, schema markup, or social sharing meta tags.
下記のコマンドをコピーしてターミナル(Mac/Linux)または PowerShell(Windows)に貼り付けてください。 ダウンロード → 解凍 → 配置まで全自動。
mkdir -p ~/.claude/skills && cd ~/.claude/skills && curl -L -o seo-best-practices.zip https://jpskill.com/download/23233.zip && unzip -o seo-best-practices.zip && rm seo-best-practices.zip
$d = "$env:USERPROFILE\.claude\skills"; ni -Force -ItemType Directory $d | Out-Null; iwr https://jpskill.com/download/23233.zip -OutFile "$d\seo-best-practices.zip"; Expand-Archive "$d\seo-best-practices.zip" -DestinationPath $d -Force; ri "$d\seo-best-practices.zip"
完了後、Claude Code を再起動 → 普通に「動画プロンプト作って」のように話しかけるだけで自動発動します。
💾 手動でダウンロードしたい(コマンドが難しい人向け)
- 1. 下の青いボタンを押して
seo-best-practices.zipをダウンロード - 2. ZIPファイルをダブルクリックで解凍 →
seo-best-practicesフォルダができる - 3. そのフォルダを
C:\Users\あなたの名前\.claude\skills\(Win)または~/.claude/skills/(Mac)へ移動 - 4. Claude Code を再起動
⚠️ ダウンロード・利用は自己責任でお願いします。当サイトは内容・動作・安全性について責任を負いません。
🎯 このSkillでできること
下記の説明文を読むと、このSkillがあなたに何をしてくれるかが分かります。Claudeにこの分野の依頼をすると、自動で発動します。
📦 インストール方法 (3ステップ)
- 1. 上の「ダウンロード」ボタンを押して .skill ファイルを取得
- 2. ファイル名の拡張子を .skill から .zip に変えて展開(macは自動展開可)
- 3. 展開してできたフォルダを、ホームフォルダの
.claude/skills/に置く- · macOS / Linux:
~/.claude/skills/ - · Windows:
%USERPROFILE%\.claude\skills\
- · macOS / Linux:
Claude Code を再起動すれば完了。「このSkillを使って…」と話しかけなくても、関連する依頼で自動的に呼び出されます。
詳しい使い方ガイドを見る →- 最終更新
- 2026-05-18
- 取得日時
- 2026-05-18
- 同梱ファイル
- 2
📖 Claude が読む原文 SKILL.md(中身を展開)
この本文は AI(Claude)が読むための原文(英語または中国語)です。日本語訳は順次追加中。
SEO Best Practices
Comprehensive SEO patterns for web applications built with React and Laravel. Contains 31 rules across 8 categories covering Core Web Vitals, technical SEO, structured data, performance, social sharing, and mobile-first indexing. Supports both coding reference and audit mode.
Metadata
- Version: 1.2.0
- Scope: Laravel Blade and Laravel + Inertia.js + React
- Rule Count: 31 rules across 8 categories
- License: MIT
How to Audit
When the user asks to "audit SEO", "check SEO", or "review SEO" — run the checklist below against their codebase.
Audit Step 1: Determine Scope
- If arguments provided (
$ARGUMENTS): audit only those pages or files - If no arguments: audit all pages and layouts in the codebase
Audit Step 2: Detect Project Type
Use the detection logic in "Step 1: Detect Project Type" below to determine Laravel Blade vs Laravel + Inertia + React.
Audit Step 3: Run SEO Checklist
Work through every item below. For each, output:
- PASS — brief confirmation of what was verified
- FAIL — exact
file:line, description of the issue, and fix recommendation - N/A — if the check does not apply to this project
Core Web Vitals
- [ ] Hero/above-the-fold images use
fetchpriority="high"and are preloaded (LCP < 2.5s) - [ ] No long-running JavaScript tasks blocking interaction (INP < 200ms)
- [ ] All images and embeds have explicit
width/heightattributes (CLS < 0.1) - [ ] No dynamically injected content that shifts layout without reserved space
Technical SEO
- [ ] Every page has a unique
<title>tag (50-60 characters) - [ ] Every page has a
<meta name="description">(150-160 characters) - [ ] Every page has a
<link rel="canonical">pointing to the correct URL - [ ]
robots.txtexists and does not block important pages - [ ] XML sitemap exists and includes all indexable pages
- [ ] URLs are clean, lowercase, hyphenated — no query params for indexable pages
On-Page SEO
- [ ] One
<h1>per page containing the primary keyword - [ ] Heading hierarchy is sequential (h1 → h2 → h3) — no skipped levels
- [ ] Images have descriptive
alttext (not empty, not "image", not filename) - [ ] Internal links use descriptive anchor text (not "click here")
- [ ] Semantic HTML used (
<article>,<section>,<nav>,<main>)
Structured Data
- [ ] JSON-LD structured data present on key pages (Article, Product, FAQ, BreadcrumbList)
- [ ] JSON-LD uses
@graphwhen combining multiple schema types - [ ] Structured data validates with Google Rich Results Test (no errors)
- [ ] Organization/WebSite schema present on homepage
Performance SEO
- [ ] Images use modern formats (WebP/AVIF) with fallbacks
- [ ] Below-the-fold images use
loading="lazy" - [ ] Fonts use
font-display: swaporoptional - [ ] Critical resources use
<link rel="preconnect">or<link rel="preload">
Social Sharing
- [ ] Open Graph tags present (
og:title,og:description,og:image,og:url,og:type) - [ ]
og:imageis at least 1200x630px - [ ] Twitter Card tags present (
twitter:card, at minimumsummary_large_image)
React/SPA SEO (if applicable)
- [ ] SSR or SSG configured for indexable pages — not client-side only
- [ ] Meta tags update on route change (via
<Head>component or equivalent) - [ ]
head-keyattribute used to prevent duplicate meta tags (Inertia.js)
Mobile-First
- [ ]
<meta name="viewport" content="width=device-width, initial-scale=1">present - [ ] Content parity between mobile and desktop (no hidden content)
- [ ] Touch targets are at least 48x48px with adequate spacing
Audit Step 4: Summary
End the audit with:
## SEO Audit Summary
- **PASS**: X checks
- **FAIL**: X checks
- **N/A**: X checks
- **Top Priority Fixes**: (list the 3 most impactful FAIL items)
When to Apply
Reference these guidelines when:
- Running an SEO audit on a codebase
- Adding meta tags (
<title>, description, canonical, robots) - Implementing structured data (JSON-LD / Schema.org)
- Optimizing Core Web Vitals (LCP, INP, CLS)
- Setting up Open Graph and Twitter Card meta tags
- Creating sitemaps and robots.txt
- Building SEO-friendly React SPAs
- Configuring Laravel SEO middleware and packages
- Optimizing images, fonts, and loading performance for search
Step 1: Detect Project Type
Always check the project stack before giving advice. Different stacks need different SEO approaches.
Check package.json and project structure:
| Signal | Project Type |
|---|---|
@inertiajs/react in dependencies |
Laravel + Inertia + React |
resources/views/**/*.blade.php only (no React) |
Laravel Blade (server-rendered) |
If Laravel Blade: Apply tech-, onpage-, schema-, perf-, social-, mobile- rules. Meta tags go in Blade layouts. Sitemaps via spatie/laravel-sitemap. Skip spa- rules — pages are already server-rendered.
If Laravel + Inertia + React: Apply all rules. Meta tags via @inertiaHead in Blade layout + <Head> component from @inertiajs/react in React pages. For SSR, create resources/js/ssr.jsx using createServer from @inertiajs/react/server, add ssr: 'resources/js/ssr.jsx' to Vite config, build with vite build && vite build --ssr, and run php artisan inertia:start-ssr. Use head-key attribute on meta tags to prevent duplicates between layout and page. Focus on schema-, social-, and perf- rules.
Rule Categories by Priority
| Priority | Category | Impact | Prefix |
|---|---|---|---|
| 1 | Core Web Vitals | CRITICAL | cwv- |
| 2 | Technical SEO | CRITICAL | tech- |
| 3 | On-Page SEO | HIGH | onpage- |
| 4 | Structured Data | HIGH | schema- |
| 5 | Performance SEO | HIGH | perf- |
| 6 | Social Sharing | HIGH | social- |
| 7 | React/SPA SEO | HIGH | spa- |
| 8 | Mobile-First | MEDIUM | mobile- |
Quick Reference
1. Core Web Vitals (CRITICAL)
cwv-lcp- Largest Contentful Paint optimization (<2.5s)cwv-inp- Interaction to Next Paint optimization (<200ms)cwv-cls- Cumulative Layout Shift prevention (<0.1)
2. Technical SEO (CRITICAL)
tech-meta-tags- Essential HTML meta tags (title, description, canonical)tech-canonical-urls- Canonical URL implementationtech-robots-txt- Robots.txt configurationtech-sitemap-xml- XML sitemap generationtech-url-structure- SEO-friendly URL patterns
3. On-Page SEO (HIGH)
onpage-headings- Heading hierarchy and structureonpage-semantic-html- Semantic HTML for SEO and accessibilityonpage-internal-linking- Internal linking strategyonpage-images- Image optimization and alt text
4. Structured Data (HIGH)
schema-json-ld- JSON-LD structured data basicsschema-article- Article and BlogPosting markupschema-product- Product schema for e-commerceschema-breadcrumb- BreadcrumbList navigation markupschema-graph- Combining multiple schema types with @graphschema-faq- FAQ page schema markupschema-validation- Structured data validation and monitoring
5. Performance SEO (HIGH)
perf-image-formats- Modern image formats (WebP/AVIF)perf-lazy-loading- Lazy loading implementationperf-font-loading- Web font loading strategyperf-resource-hints- Preconnect, preload, and prefetch
6. Social Sharing (HIGH)
social-open-graph- Open Graph meta tagssocial-twitter-cards- Twitter/X Card meta tags
7. React/SPA SEO (HIGH)
spa-rendering-strategy- SSR vs CSR vs SSG for SEOspa-meta-management- Dynamic meta tag managementspa-routing- SPA routing and crawlability
8. Mobile-First (MEDIUM)
mobile-viewport- Viewport and responsive configurationmobile-content-parity- Content parity between mobile and desktopmobile-ux- Mobile UX requirements for SEO
Essential Patterns
Meta Tags (HTML)
<head>
<meta charset="utf-8" />
<meta name="viewport" content="width=device-width, initial-scale=1" />
<title>Page Title — Site Name</title>
<meta name="description" content="Concise 150-160 character description of page content." />
<link rel="canonical" href="https://example.com/page" />
<!-- Open Graph -->
<meta property="og:title" content="Page Title" />
<meta property="og:description" content="Description for social sharing." />
<meta property="og:image" content="https://example.com/og-image.jpg" />
<meta property="og:url" content="https://example.com/page" />
<meta property="og:type" content="website" />
<!-- Twitter Card -->
<meta name="twitter:card" content="summary_large_image" />
</head>
JSON-LD Structured Data
<script type="application/ld+json">
{
"@context": "https://schema.org",
"@type": "Article",
"headline": "Article Title",
"author": {
"@type": "Person",
"name": "Author Name"
},
"datePublished": "2026-03-14",
"dateModified": "2026-03-14",
"image": "https://example.com/article-image.jpg",
"publisher": {
"@type": "Organization",
"name": "Site Name",
"logo": {
"@type": "ImageObject",
"url": "https://example.com/logo.png"
}
}
}
</script>
React Meta Management (Inertia.js)
import { Head } from '@inertiajs/react'
interface Post {
title: string;
slug: string;
excerpt: string;
image: string;
}
function BlogPost({ post }: { post: Post }) {
return (
<>
<Head>
<title>{post.title} — Blog</title>
<meta head-key="description" name="description" content={post.excerpt} />
<link rel="canonical" href={`https://example.com/blog/${post.slug}`} />
<meta property="og:title" content={post.title} />
<meta property="og:description" content={post.excerpt} />
<meta property="og:image" content={post.image} />
<meta property="og:type" content="article" />
<meta name="twitter:card" content="summary_large_image" />
</Head>
<article>{/* content */}</article>
</>
)
}
Core Web Vitals Quick Checks
LCP < 2.5s Preload hero image, use fetchpriority="high"
INP < 200ms Break long tasks, yield to main thread
CLS < 0.1 Set width/height on images, reserve space for dynamic content
Image Optimization
<!-- Modern formats with fallback -->
<picture>
<source srcset="hero.avif" type="image/avif" />
<source srcset="hero.webp" type="image/webp" />
<img
src="hero.jpg"
alt="Descriptive alt text for the image"
width="1200"
height="630"
fetchpriority="high"
/>
</picture>
<!-- Responsive images -->
<img
srcset="photo-400.webp 400w, photo-800.webp 800w, photo-1200.webp 1200w"
sizes="(max-width: 600px) 400px, (max-width: 900px) 800px, 1200px"
src="photo-800.webp"
alt="Descriptive alt text"
width="1200"
height="800"
loading="lazy"
/>
How to Use
Read individual rule files for detailed explanations and code examples:
rules/tech-meta-tags.md
rules/schema-json-ld.md
rules/cwv-lcp.md
rules/spa-rendering-strategy.md
rules/social-open-graph.md
Each rule file contains:
- YAML frontmatter with metadata (title, impact, tags)
- Brief explanation of why it matters
- Incorrect example with explanation
- Correct example with explanation
- Framework-specific examples (React, Laravel)
References
- Google Search Central - Official Google SEO documentation
- web.dev Core Web Vitals - CWV measurement and optimization
- Schema.org - Structured data vocabulary
- Open Graph Protocol - Social sharing meta tags
- Google Rich Results Test - Structured data validation
Full Compiled Document
For the complete guide with all rules expanded: AGENTS.md
同梱ファイル
※ ZIPに含まれるファイル一覧。`SKILL.md` 本体に加え、参考資料・サンプル・スクリプトが入っている場合があります。
- 📄 SKILL.md (12,396 bytes)
- 📎 README.md (2,045 bytes)