Guide
This plugin will make your site fully support Open Content Protocol OGP and JSON-LD 1.1 to enhance the SEO of the site.
Out of Box
The plugin works out of the box. Without any config, it will extract information from the page content as much as possible to complete the necessary tags required by OGP and JSON-LD.
By default, the plugin will read the site config and page frontmatter to automatically generate tags as much as possible. Such as site name, page title, page type, writing date, last update date, and article tags are all automatically generated.
The following are the <meta>
tags and their values that will be injected into <head>
by default:
Default OGP Generation
The following are the <meta>
tags and their value injected into <head>
by default to satisfy OGP:
Meta Name | Value |
---|---|
og:url | options.hostname + path |
og:site_name | siteConfig.title |
og:title | page.title |
og:description | page.frontmatter.description || auto generated (when autoDescription is true in plugin options) |
og:type | "article" |
og:image | page.frontmatter.banner || page.frontmatter.cover || first image in page || fallbackImage in plugin options |
og:updated_time | page.git.updatedTime |
og:locale | page.lang |
og:locale:alternate | Other languages in siteData.locales |
twitter:card | "summary_large_image" (only available when image found) |
twitter:image:alt | page.title (only available when image found) |
article:author | page.frontmatter.author || options.author |
article:tag | page.frontmatter.tags || page.frontmatter.tag |
article:published_time | page.frontmatter.date || page.git.createdTime |
article:modified_time | page.git.updatedTime |
Default JSON-LD Generation
Property Name | Value |
---|---|
@context | "https://schema.org" |
@type | "NewsArticle" |
headline | page.title |
image | image in page || options.hostname + page.frontmatter.image || siteFavIcon in plugin options |
datePublished | page.frontmatter.date || page.git.createdTime |
dateModified | page.git.updatedTime |
author | page.frontmatter.author || options.author |
Setting Tags Directly
You can configure the head
option in the page's frontmatter to add specific tags to the page <head>
to enhance SEO. For example:
---
head:
- - meta
- name: keywords
content: SEO plugin
---
Will automatically inject <meta name="keywords" content="SEO plugin" />
.
Customize Generation
The plugin also gives you full control over the build logic.
Page Type
For most pages, there are basically only two types: articles and website, so the plugin provides the isArticle
option to allow you to provide logic for identifying articles.
The option accepts a function in the format (page: Page) => boolean
, by default all non-home pages generated from Markdown files are treated as articles.
Tips
If a page does fit into the "unpopular" genre like books, music, etc., you can handle them by setting the three options below.
OGP
You can use the plugin options ogp
to pass in a function to modify the default OGP object to your needs and return it.
function ogp(
/** OGP Object inferred by plugin */
ogpInfo: SeoContent,
/** Page Object */
page: Page,
/** VuePress App */
app: App,
): SeoContent
For detailed parameter structure, see Config.
For example, if you are using a third-party theme and set a banner
in frontmatter for each article according to the theme requirements, then you can pass in the following ogp
:
seoPlugin({
ogp: (ogp, page) => ({
...ogp,
'og:image': page.frontmatter.banner || ogp['og:image'],
}),
})
JSON-LD
Like OGP, you can use the plugin options jsonLd
to pass in a function to modify the default JSON-LD object to your needs and return it.
function jsonLd(
/** JSON-LD Object inferred by plugin */
jsonLD: ArticleSchema | BlogPostingSchema | WebPageSchema,
/** Page Object */
page: Page,
/** VuePress App */
app: App,
): ArticleSchema | BlogPostingSchema | WebPageSchema
Canonical Link
If you are deploying your content to different sites, or same content under different URLs, you may need to set canonical
option to provide a "Canonical Link" for your page. You can either set a string which will be appended before page route link, or adding a custom function (page: Page) => string | null
to return a canonical link if necessary.
Example
If your sites are deployed under docs directory in example.com
, but available in:
http://example.com/docs/xxx
https://example.com/docs/xxx
http://www.example.com/docs/xxx
https://www.example.com/docs/xxx
(primary)
To let search engine results always be the primary choice, you may need to set canonical
to https://www.example.com/docs/
, so that search engine will know that the fourth URL is preferred to be indexed.
Customize head Tags
Sometimes you may need to fit other protocols or provide the corresponding SEO tags in the format provided by other search engines. In this case, you can use the customHead
option, whose type is:
function customHead(
/** Head tag config */
head: HeadConfig[],
/** Page Object */
page: Page,
/** VuePress App */
app: App,
): void
You should modify the head
array in this function directly.
SEO Introduction
Search engine optimization (SEO) is the process of improving the quality and quantity of site traffic to a site or a web page from search engines. SEO targets unpaid traffic (known as "natural" or "organic" results) rather than direct traffic or paid traffic. Unpaid traffic may originate from different kinds of searches, including image search, video search, academic search, news search, and industry-specific vertical search engines.
As an internet marketing strategy, SEO considers how search engines work, the computer-programmed algorithms that dictate search engine behavior, what people search for, the actual search terms or keywords typed into search engines, and which search engines are preferred by their targeted audience. SEO is performed because a site will receive more visitors from a search engine when sites rank higher on the search engine results page (SERP). These visitors can then potentially be converted into customers.
Related Documents
Open Content Protocol OGP (Open Graph Protocol)
This plugin perfectly supports this protocol and will automatically generate
<meta>
tags that conform to the protocol.This plugin will generate "NewsArticle" scheme for article pages.
RDFa mainly marks HTML structure. This is what the plugin cannot support. uses this feature to pass Google's rich media structure test. You can consider using it.
Schema definition site for structural markup
Related Tools
You can use Google Rich Media Structure Test Tool to test this site.