Writing a Plugin

TIP

Before reading this guide, you'd better learn the VuePress architecture first.

Create a Plugin

A VuePress plugin is a plain JavaScript object that satisfies the Plugin API, which is called a Plugin Object.

If a plugin wants to receive user options, it could be a function that returns a Plugin Object, which is called a Plugin Function.

const fooPlugin = {
  name: 'vuepress-plugin-foo',
  // ...
}
1
2
3
4
const fooPlugin = (options, app) => {
  return {
    name: 'vuepress-plugin-foo',
    // ...
  }
}
1
2
3
4
5
6

Publish to NPM

The typical structure of a plugin package is as follow:

vuepress-plugin-foo
├─ lib
│  └─ index.js
└─ package.json
1
2
3
4

Plugin Entry

The lib/index.js file is the plugin entry, which should export the plugin directly:

module.exports = fooPlugin
1
export default fooPlugin
1

TIP

Notice that the plugin entry will be loaded in Node, so it should be in CommonJS format.

If you are using ESM format, you'll need to use babelopen in new window or typescriptopen in new window to transpile it into CommonJS.

package.json

The package.jsonopen in new window file is required to publish a package to NPM:

{
  "name": "vuepress-plugin-foo",
  "version": "1.0.0",
  "keywords": [
    "vuepress-plugin",
  ],
  "main": "lib/index.js",
  "files": [
    "lib"
  ]
}
1
2
3
4
5
6
7
8
9
10
11
  • Set name to follow the naming convention: vuepress-plugin-xxx or @org/vuepress-plugin-xxx.
  • Set keywords to include vuepress-plugin, so that users can search your plugin on NPM.
  • Set main to the plugin entry file.
  • Set files to only publish those files inside lib directory.