Yoast SEO Shopify: Schema output
This page documents the schema.org markup output by the Yoast SEO for Shopify app.
The output is generally consistent with our general approach, but has some minor variations due to differences in platform mechanics.
Structured data and microdata removal
Many Shopify websites and themes include schema 'fragments'; e.g., isolated pieces of inline microdata, disconnected JSON-LD nodes, and thin or duplicate entity descriptions. To prevent potential conflicts and errors, we attempt to remove all existing structured data (in JSON-LD, and in microdata formats) from theme template when our app is installed.
Most apps which add structured data functionality (e.g., reviews, recipes, etc) shouldn't be affected, provided that they don't place their scripts directly in the theme code.
Core logic
Every page should (attempt to) output the following pieces:
Note that this is dependent upon the following in the app's schema settings:
- The Organization's name and logo being defined, and;
- The respective pieces being enabled.
When these criteria are met, we produce our base script. In a Shopify store, this will typically looks something like the following (a composite of the above pieces):
{
"@context": "https://schema.org",
"@graph": [
{
"@type": "Organization",
"@id": "https://www.example.com/#/schema/organization/1",
"url": "https://www.example.com",
"name": "Example organization name",
"logo": {
"@id": "https://www.example.com/#/schema/ImageObject/1234"
},
"image": [
{
"@id": "https://www.example.com/#/schema/ImageObject/1234"
}
],
"sameAs": [
"https://www.wikipedia.com/example-organization",
"https://facebook.com/example-organization",
"https://twitter.com/example-organization",
"https://www.instagram.com/example-organization"
]
},
{
"@type": "ImageObject",
"@id": "https://www.example.com/#/schema/ImageObject/1234",
"url": "https://www.example.com/content/images/image.jpg",
"contentUrl": "https://www.example.com/content/images/image.jpg",
"width": 520,
"height": 240
},
{
"@type": "WebSite",
"@id": "https://www.example.com/#/schema/website/1",
"url": "https://www.example.com",
"name": "Example store",
"potentialAction": {
"@type": "SearchAction",
"target": "https://www.example.com/search?q={search_term_string}",
"query-input": "required name=search_term_string"
},
"inLanguage": "en",
"publisher": {
"@id": "https://www.example.com/#/schema/organization/1"
}
},
{
"@type": [
"WebPage",
"CollectionPage"
],
"@id": "https://www.example.com/",
"url": "https://www.example.com/",
"name": "Example store",
"about": {
"@id": "https://www.example.com/#/schema/organization/1"
},
"breadcrumb": {
"@id": "https://www.example.com/#/schema/breadcrumb"
},
"isPartOf": {
"@id": "https://www.example.com/#/schema/website/1"
}
},
{
"@type": "BreadcrumbList",
"@id": "https://www.example.com/#/schema/breadcrumb",
"itemListElement": [
{
"@type": "ListItem",
"name": "Example store",
"position": 1
}
]
}
]
}
On product pages
Example
{
"@context": "https://schema.org",
"@graph": [
{
"@type": "Product",
"@id": "https://www.example.com/products/example-product/#/schema/Product",
"mainEntityOfPage": {
"@id": "https://www.example.com/products/example-product"
},
"name": "Example product",
"image": {
"@id": "https://www.example.com/#/schema/image/abc123"
},
"description": "Product description",
"sku": "abc123",
"url": "https://www.example.com/products/example-product",
"offers": {
"@type": "AggregateOffer",
"@id": "https://www.example.com/products/example-product/#/schema/AggregateOffer",
"availability": "https://schema.org/InStock",
"offerCount": 1,
"lowPrice": 10.0,
"highPrice": 10.0,
"priceCurrency": "EUR",
"url": "https://www.example.com/products/example-product",
"priceSpecification": {
"@type": "PriceSpecification",
"valueAddedTaxIncluded": true
}
}
}
]
}
On blog posts
- Add an
Article
piece