schema

Когда пользователь хочет добавить, исправить или оптимизировать разметку schema и структурированные данные на своем сайте. Также используйте, когда пользователь упоминает «разметка schema», «структурированные данные», «JSON-LD», «rich snippets», «schema.org», «схема FAQ», «схема товара», «схема отзыва», «схема хлебных крошек», «расширенные результаты Google», «панель знаний», «звездные рейтинги в поиске» или «добавить структурированные данные». Используйте это всякий раз, когда кто-то хочет, чтобы его страницы отображали улучшенные результаты в Google. Для более широких вопросов SEO см. seo-audit. Для 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

Больше skills от coreyhaines31

copywriting
coreyhaines31
Когда пользователь хочет написать, переписать или улучшить маркетинговый текст для любой страницы — включая главную, посадочные страницы, страницы с ценами, страницы функций, страницу «О нас» или страницы продуктов. Также используйте, когда пользователь говорит: «напиши текст для», «улучши этот текст», «перепиши эту страницу», «маркетинговый текст», «помощь с заголовком», «текст для CTA», «ценностное предложение», «слоган», «подзаголовок», «текст для геройского раздела», «выше сгиба», «этот текст слабый», «сделай это более убедительным» или «помоги мне описать мой продукт». Используйте это...
marketingcreativecommunication
seo-audit
coreyhaines31
Когда пользователь хочет провести аудит, проверить или диагностировать проблемы SEO на своем сайте. Также используйте, когда пользователь упоминает «SEO-аудит», «техническое SEO», «почему я не ранжируюсь», «проблемы SEO», «внутренняя оптимизация», «проверка мета-тегов», «проверка здоровья SEO», «мой трафик упал», «потерял позиции», «не отображаюсь в Google», «сайт не ранжируется», «меня затронуло обновление Google», «скорость страницы», «основные веб-показатели», «ошибки сканирования» или «проблемы индексации». Используйте это, даже если пользователь просто говорит что-то неопределенное, например «у меня плохое SEO» или «помогите...»
marketingresearchdata-analysis
marketing-psychology
coreyhaines31
Когда пользователь хочет применить психологические принципы, ментальные модели или поведенческую науку в маркетинге. Также используйте, когда пользователь упоминает «психологию», «ментальные модели», «когнитивное искажение», «убеждение», «поведенческую науку», «почему люди покупают», «принятие решений», «поведение потребителей», «якорение», «социальное доказательство», «дефицит», «неприятие потерь», «фрейминг» или «подталкивание». Используйте это всякий раз, когда кто-то хочет понять или использовать то, как люди думают и принимают решения в маркетинговом контексте. Для применения...
marketingresearch
content-strategy
coreyhaines31
Когда пользователь хочет спланировать контент-стратегию, решить, какой контент создавать, или определить темы для освещения. Также используйте, когда пользователь упоминает «контент-стратегия», «о чем мне писать», «идеи для контента», «стратегия блога», «тематические кластеры», «планирование контента», «редакционный календарь», «контент-маркетинг», «дорожная карта контента», «какой контент мне создать», «темы для блога», «столпы контента» или «я не знаю, что писать». Используйте это всякий раз, когда кому-то нужна помощь в решении, какой контент...
marketingresearchcreative
ai-seo
coreyhaines31
Когда пользователь хочет оптимизировать контент для AI-поисковиков, получить цитирование от LLM или появляться в AI-сгенерированных ответах. Также используйте, когда пользователь упоминает «AI SEO», «AEO», «GEO», «LLMO», «оптимизация для поисковых систем с ответами», «оптимизация для генеративных движков», «оптимизация для LLM», «AI Overviews», «оптимизация для ChatGPT», «оптимизация для Perplexity», «AI-цитирование», «AI-видимость», «поиск с нулевым кликом», «как мне появиться в AI-ответах», «упоминания в LLM» или «оптимизация для Claude/Gemini». Используйте это всякий раз, когда кто-то...
marketingresearch
programmatic-seo
coreyhaines31
Когда пользователь хочет массово создавать SEO-ориентированные страницы с использованием шаблонов и данных. Также используйте, когда пользователь упоминает «программное SEO», «страницы по шаблонам», «массовое создание страниц», «страницы каталогов», «страницы локаций», «страницы [ключевое слово] + [город]», «страницы сравнения», «страницы интеграций», «создание множества страниц для SEO», «pSEO», «сгенерировать 100 страниц», «страницы на основе данных» или «шаблонные лендинги». Используйте это всякий раз, когда кто-то хочет создать множество похожих страниц, нацеленных на разные ключевые слова или локации. Для...
marketingdata-analysisweb-scraping
marketing-ideas
coreyhaines31
Когда пользователю нужны маркетинговые идеи, вдохновение или стратегии для его SaaS или программного продукта. Также используйте, когда пользователь спрашивает о «маркетинговых идеях», «идеях для роста», «как продвигать», «маркетинговых стратегиях», «маркетинговых тактиках», «способах продвижения», «идеях для роста», «что ещё можно попробовать», «я не знаю, как это продвигать», «мозговой штурм маркетинга» или «какой маркетинг мне выбрать». Используйте это как отправную точку, когда кто-то застрял или ищет вдохновения для роста. Для конкретных...
marketing
copy-editing
coreyhaines31
Когда пользователь хочет отредактировать, проверить или улучшить существующий маркетинговый текст, или обновить устаревший контент. Также используйте, когда пользователь упоминает «отредактируй этот текст», «проверь мой текст», «отзыв о тексте», «вычитка», «отполируй это», «сделай это лучше», «проверка текста», «сократи это», «это читается неестественно», «очисти этот текст», «слишком многословно», «улучши формулировки», «обнови этот контент», «обнови эту страницу», «этот контент устарел» или «аудит контента». Используйте это, когда у пользователя уже есть текст и он хочет его...
documentcommunicationmarketing