DEV Community

DET171
DET171

Posted on • Originally published at det171.github.io

VuePress tips for development and productions

Introduction

I assume that if you're reading this, you have used VuePress or want to use VuePress to make a site. I will be using VuePress 2 for this post.

Bundlers: Using Vite for development, Webpack for production

Vite is much faster than Webpack when it comes to bundling packages, as it uses esbuild to pre-bundle dependencies, and serves source code over native ESM. However, Vite cannot bundle code for older browsers (e.g. non ESM code). Webpack, on the other hand, can accomplish that, but is slower in bundling. Even its HMR can be quite slow when your project is humongous.

However, the question now is how do I accomplish it? In fact, it's quite easy.
Open your config.js (or config.ts). You should see something like the following:

module.exports = {
  // ...
  title: 'Title',
  description: 'Description',
  head: [
    ['meta', { name: 'theme-color', content: '#7354ff' }],
    ['meta', { name: 'apple-mobile-web-app-capable', content: 'yes' }],
    ['meta', { name: 'apple-mobile-web-app-status-bar-style', content: 'black' }]
  ],
  themeConfig: {
    // ...
  }
}
Enter fullscreen mode Exit fullscreen mode

Put the following just before module.exports:

const isProd = process.env.NODE_ENV === 'production'
Enter fullscreen mode Exit fullscreen mode

In case you haven't read the VuePress docs, you can set the bundler using the bundler option.
Add the following under module.exports:

bundler: process.env.DOCS_BUNDLER ?? (isProd ? '@vuepress/webpack' : '@vuepress/vite'),
Enter fullscreen mode Exit fullscreen mode

We assume the scripts section of your package.json looks something like the following:

"scripts": {
  "dev": "vuepress dev src",
  "build": "vuepress build src"
}
Enter fullscreen mode Exit fullscreen mode

Change it to the following:

"scripts": {
  "dev": "NODE_ENV=development vuepress dev src",
  "build": "NODE_ENV=production vuepress build src"
}
Enter fullscreen mode Exit fullscreen mode

The NODE_ENV=development sets the value of process.env.NODE_ENV. If you want to specify what bundler you want to use without setting NODE_ENV, you just have to add DOCS_BUNDLER=@vuepress/webpack or DOCS_BUNDLER=@vuepress/vite to the scripts the same way we added NODE_ENV.

Using PrismJS during development and Shiki during production

PrismJS is regex based, so has known fail cases. As mentioned on the VuePress docs, Shiki has higher fidelity than PrismJS, and as an added bonus, accepts VS Code themes (which means it has more themes than PrismJS).

To use PrismJS and Shiki during development and production respectively, go to the plugins section under themeConfig, and add the following:

[
  '@vuepress/plugin-shiki',
  isProd
    ? {
      theme: 'dracula', // see https://github.com/shikijs/shiki/blob/main/docs/themes.md for themes
    }
  : false,
],
Enter fullscreen mode Exit fullscreen mode

Your config.js or config.ts should now look something like this:

module.exports = {
  bundler: process.env.DOCS_BUNDLER ?? (isProd ? '@vuepress/webpack' : '@vuepress/vite'),
  // ...
  title: 'Title',
  description: 'Description',
  head: [
    ['meta', { name: 'theme-color', content: '#7354ff' }],
    ['meta', { name: 'apple-mobile-web-app-capable', content: 'yes' }],
    ['meta', { name: 'apple-mobile-web-app-status-bar-style', content: 'black' }]
  ],
  themeConfig: {
    // ...
    plugins: [
      [
      '@vuepress/plugin-shiki',
      isProd
        ? {
            theme: 'dracula',
          }
        : false,
      ],
    ]
  }
}
Enter fullscreen mode Exit fullscreen mode

Hope this post helped!

Top comments (0)