Skip to content

Latest commit

 

History

History
56 lines (45 loc) · 1.4 KB

README.md

File metadata and controls

56 lines (45 loc) · 1.4 KB

vue-schema-microdata

Vue plugin/directive for adding schema.org microdata tags to your markup

Install

npm install vue-schema-microdata
# or
yarn add vue-schema-microdata

Basic usage

// Import and install plugin
import VueSchemaMicrodata from 'vue-schema-microdata'
Vue.use(VueSchemaMicrodata)
<!-- Use v-schema directive in your markup -->

<div v-schema:scope="{ type: 'Product', prop: 'itemListElement' }">
    <a href="#" v-schema="{ prop: 'url'}">
        <img src="https://via.placeholder.com/150x100?text=ProductImage" v-schema="{ prop: 'image' }" />
    </a>
    <h2 v-schema="{ prop: 'name' }">Product name</h2>
    <h4 v-schema="{ prop: 'category' }">Product category</h4>
    <div v-schema:scope="{ type: 'Offer', prop: 'offers' }">
        <span v-schema="{ prop: 'priceCurrency', content: 'USD' }">$</span>
        <span v-schema="{ prop: 'price' }">129.80</span>
    </div>
</div>

Itemscope

<div v-schema:scope> ... </div>

<!-- or -->

<div v-schema="{ scope: true }"> ... </div>

Itemtype

<div v-schema:scope="{ type: 'Movie' }"> ... </div>

Types will be prefixed with "https://schema.org/" by default. You can change this URL with the schemaUrl property in the plugin settings.

Itemprop

<img v-schema="{ prop: 'image' }" />

<!-- with additional tags -->
<span v-schema="{ prop: 'priceCurrency', content: 'USD' }">$</span>