Passing Data to Client Code

As we know, VuePress plugin entries and theme entries are processed in Node side, but sometimes you might need to pass data to client side. For example, you want to generate different data when users use different options.

Use define Hook

Plugin API provides a define hook to define global constants for client code. You can make use of it to pass data to client.

First, define some constants in define hook:

module.exports = (options) => ({
  define: {
    __FOO__: options.foo || 'str',
    __OBJ__: {
      bar: options.bar || 123,
    },
  },
})
1
2
3
4
5
6
7
8

Then use them in client code directly:

const foo = __FOO__
const obj = __OBJ__
1
2

If you are using TypeScript in client code, you may need to declare the types of the global constants manually:

declare const __FOO__: string
declare const __OBJ__: { bar: number }
1
2

Write and Load Temp Files

If you need to achieve some more complex features, you can write temp files and load them dynamically in client code.

First, write a temp file foo.js, which will be generated in the temp directory:

module.exports = (options) => ({
  async onPrepared(app) {
    // write temp file
    await app.writeTemp('foo.js', `export const foo = ${JSON.stringify(options.foo)}`)
  },
})
1
2
3
4
5
6

Then, load the temp file via @temp alias in client code:

import { foo } from '@temp/foo'
1

If you are using TypeScript in client code, you may need to declare the type of the temp module manually:

declare module '@temp/foo' {
  export const foo: string
}
1
2
3