schema

When the user wants to add, fix, or optimize schema markup and structured data on their site. Also use when the user mentions "schema markup," "structured data," "JSON-LD," "rich snippets," "schema.org," "FAQ schema," "product schema," "review schema," "breadcrumb schema," "Google rich results," "knowledge panel," "star ratings in search," or "add structured data." Use this whenever someone wants their pages to show enhanced results in Google. For broader SEO issues, see seo-audit. For AI...

npx skills add https://github.com/coreyhaines31/marketingskills --skill schema

Schema Markup

You are an expert in structured data and schema markup. Your goal is to implement schema.org markup that helps search engines understand content and enables rich results in search.

Initial Assessment

Check for product marketing context first: If .agents/product-marketing.md exists (or .claude/product-marketing.md, or the legacy product-marketing-context.md filename, in older setups), read it before asking questions. Use that context and only ask for information not already covered or specific to this task.

Before implementing schema, understand:

  1. Page Type - What kind of page? What's the primary content? What rich results are possible?

  2. Current State - Any existing schema? Errors in implementation? Which rich results already appearing?

  3. Goals - Which rich results are you targeting? What's the business value?


Core Principles

1. Accuracy First

  • Schema must accurately represent page content
  • Don't markup content that doesn't exist
  • Keep updated when content changes

2. Use JSON-LD

  • Google recommends JSON-LD format
  • Easier to implement and maintain
  • Place in <head> or end of <body>

3. Follow Google's Guidelines

  • Only use markup Google supports
  • Avoid spam tactics
  • Review eligibility requirements

4. Validate Everything

  • Test before deploying
  • Monitor Search Console
  • Fix errors promptly

Common Schema Types

TypeUse ForRequired Properties
OrganizationCompany homepage/aboutname, url
WebSiteHomepage (search box)name, url
ArticleBlog posts, newsheadline, image, datePublished, author
ProductProduct pagesname, image, offers
SoftwareApplicationSaaS/app pagesname, offers
FAQPageFAQ contentmainEntity (Q&A array)
HowToTutorialsname, step
BreadcrumbListAny page with breadcrumbsitemListElement
LocalBusinessLocal business pagesname, address
EventEvents, webinarsname, startDate, location

For complete JSON-LD examples: See references/schema-examples.md


Quick Reference

Organization (Company Page)

Required: name, url Recommended: logo, sameAs (social profiles), contactPoint

Article/BlogPosting

Required: headline, image, datePublished, author Recommended: dateModified, publisher, description

Product

Required: name, image, offers (price + availability) Recommended: sku, brand, aggregateRating, review

FAQPage

Required: mainEntity (array of Question/Answer pairs)

BreadcrumbList

Required: itemListElement (array with position, name, item)


Multiple Schema Types

You can combine multiple schema types on one page using @graph:

{
  "@context": "https://schema.org",
  "@graph": [
    { "@type": "Organization", ... },
    { "@type": "WebSite", ... },
    { "@type": "BreadcrumbList", ... }
  ]
}

Validation and Testing

Tools

Common Errors

Missing required properties - Check Google's documentation for required fields

Invalid values - Dates must be ISO 8601, URLs fully qualified, enumerations exact

Mismatch with page content - Schema doesn't match visible content


Implementation

Static Sites

  • Add JSON-LD directly in HTML template
  • Use includes/partials for reusable schema

Dynamic Sites (React, Next.js)

  • Component that renders schema
  • Server-side rendered for SEO
  • Serialize data to JSON-LD

CMS / WordPress

  • Plugins (Yoast, Rank Math, Schema Pro)
  • Theme modifications
  • Custom fields to structured data

Output Format

Schema Implementation

// Full JSON-LD code block
{
  "@context": "https://schema.org",
  "@type": "...",
  // Complete markup
}

Testing Checklist

  • Validates in Rich Results Test
  • No errors or warnings
  • Matches page content
  • All required properties included

Task-Specific Questions

  1. What type of page is this?
  2. What rich results are you hoping to achieve?
  3. What data is available to populate the schema?
  4. Is there existing schema on the page?
  5. What's your tech stack?

Related Skills

  • seo-audit: For overall SEO including schema review
  • ai-seo: For AI search optimization (schema helps AI understand content)
  • programmatic-seo: For templated schema at scale
  • site-architecture: For breadcrumb structure and navigation schema planning

Lebih banyak skill dari coreyhaines31

copywriting
coreyhaines31
Ketika pengguna ingin menulis, menulis ulang, atau meningkatkan salinan pemasaran untuk halaman apa pun — termasuk halaman beranda, halaman arahan, halaman harga, halaman fitur, halaman tentang, atau halaman produk. Juga gunakan ketika pengguna mengatakan "tulis salinan untuk," "tingkatkan salinan ini," "tulis ulang halaman ini," "salinan pemasaran," "bantuan judul," "salinan CTA," "proposisi nilai," "tagline," "subjudul," "salinan bagian hero," "di atas lipatan," "salinan ini lemah," "buat ini lebih menarik," atau "bantu saya mendeskripsikan produk saya." Gunakan ini...
marketingcreativecommunication
seo-audit
coreyhaines31
Ketika pengguna ingin mengaudit, meninjau, atau mendiagnosis masalah SEO di situs mereka. Gunakan juga ketika pengguna menyebutkan "audit SEO," "SEO teknis," "kenapa saya tidak naik peringkat," "masalah SEO," "SEO on-page," "tinjauan meta tag," "pemeriksaan kesehatan SEO," "trafik saya turun," "peringkat hilang," "tidak muncul di Google," "situs tidak naik peringkat," "pembaruan Google berdampak pada saya," "kecepatan halaman," "core web vitals," "kesalahan perayapan," atau "masalah pengindeksan." Gunakan ini bahkan jika pengguna hanya mengatakan sesuatu yang samar seperti "SEO saya buruk" atau "bantu...
marketingresearchdata-analysis
marketing-psychology
coreyhaines31
Ketika pengguna ingin menerapkan prinsip psikologi, model mental, atau ilmu perilaku dalam pemasaran. Gunakan juga ketika pengguna menyebut 'psikologi,' 'model mental,' 'bias kognitif,' 'persuasi,' 'ilmu perilaku,' 'mengapa orang membeli,' 'pengambilan keputusan,' 'perilaku konsumen,' 'penjangkaran,' 'bukti sosial,' 'kelangkaan,' 'keengganan kehilangan,' 'pembingkaian,' atau 'dorongan.' Gunakan ini setiap kali seseorang ingin memahami atau memanfaatkan cara orang berpikir dan mengambil keputusan dalam konteks pemasaran. Untuk menerapkan...
marketingresearch
content-strategy
coreyhaines31
Ketika pengguna ingin merencanakan strategi konten, memutuskan konten apa yang akan dibuat, atau menentukan topik apa yang akan dibahas. Gunakan juga ketika pengguna menyebutkan "strategi konten," "apa yang harus saya tulis," "ide konten," "strategi blog," "kluster topik," "perencanaan konten," "kalender editorial," "pemasaran konten," "peta jalan konten," "konten apa yang harus saya buat," "topik blog," "pilar konten," atau "saya tidak tahu harus menulis apa." Gunakan ini setiap kali seseorang membutuhkan bantuan untuk memutuskan konten apa yang akan...
marketingresearchcreative
ai-seo
coreyhaines31
Ketika pengguna ingin mengoptimalkan konten untuk mesin pencari AI, dikutip oleh LLM, atau muncul dalam jawaban yang dihasilkan AI. Gunakan juga ketika pengguna menyebut 'AI SEO,' 'AEO,' 'GEO,' 'LLMO,' 'answer engine optimization,' 'generative engine optimization,' 'LLM optimization,' 'AI Overviews,' 'optimize for ChatGPT,' 'optimize for Perplexity,' 'AI citations,' 'AI visibility,' 'zero-click search,' 'how do I show up in AI answers,' 'LLM mentions,' atau 'optimize for Claude/Gemini.' Gunakan ini setiap kali seseorang...
marketingresearch
programmatic-seo
coreyhaines31
Ketika pengguna ingin membuat halaman berbasis SEO dalam skala besar menggunakan templat dan data. Gunakan juga ketika pengguna menyebutkan "programmatic SEO," "halaman templat," "halaman dalam skala besar," "halaman direktori," "halaman lokasi," "halaman [kata kunci] + [kota]," "halaman perbandingan," "halaman integrasi," "membangun banyak halaman untuk SEO," "pSEO," "buat 100 halaman," "halaman berbasis data," atau "halaman arahan templat." Gunakan ini setiap kali seseorang ingin membuat banyak halaman serupa yang menargetkan kata kunci atau lokasi berbeda. Untuk...
marketingdata-analysisweb-scraping
marketing-ideas
coreyhaines31
Ketika pengguna membutuhkan ide pemasaran, inspirasi, atau strategi untuk produk SaaS atau perangkat lunak mereka. Juga gunakan ketika pengguna bertanya tentang 'ide pemasaran,' 'ide pertumbuhan,' 'cara memasarkan,' 'strategi pemasaran,' 'taktik pemasaran,' 'cara mempromosikan,' 'ide untuk berkembang,' 'apa lagi yang bisa saya coba,' 'saya tidak tahu cara memasarkan ini,' 'brainstorming pemasaran,' atau 'pemasaran apa yang harus saya lakukan.' Gunakan ini sebagai titik awal setiap kali seseorang bingung atau mencari inspirasi tentang cara berkembang. Untuk spesifik...
marketing
copy-editing
coreyhaines31
Ketika pengguna ingin menyunting, meninjau, atau meningkatkan naskah pemasaran yang sudah ada, atau menyegarkan konten yang usang. Gunakan juga ketika pengguna menyebut 'edit naskah ini,' 'tinjau naskah saya,' 'masukan naskah,' 'proofread,' 'perhalus ini,' 'buat ini lebih baik,' 'sapu bersih naskah,' 'rapikan ini,' 'ini terbaca kaku,' 'bersihkan teks ini,' 'terlalu bertele-tele,' 'tajamkan pesannya,' 'segerakan konten ini,' 'perbarui halaman ini,' 'konten ini sudah usang,' atau 'audit konten.' Gunakan ini ketika pengguna sudah memiliki naskah dan menginginkannya...
documentcommunicationmarketing