2.4 KiB
Asset Handling
All Markdown files are compiled into Vue components and processed by Vite. You can, and should, reference any assets using relative URLs:
![An image](./image.png)
You can reference static assets in your markdown files, your *.vue
components in the theme, styles and plain .css
files either using absolute public paths (based on project root) or relative paths (based on your file system). The latter is similar to the behavior you are used to if you have used vue-cli
or webpack's file-loader
.
Common image, media, and font filetypes are detected and included as assets automatically.
All referenced assets, including those using absolute paths, will be copied to the dist folder with a hashed file name in the production build. Never-referenced assets will not be copied. Similar to vue-cli
, image assets smaller than 4kb will be base64 inlined.
All static path references, including absolute paths, should be based on your working directory structure.
Public Files
Sometimes you may need to provide static assets that are not directly referenced in any of your Markdown or theme components (for example, favicons and PWA icons). The public
directory under project root can be used as an escape hatch to provide static assets that either are never referenced in source code (e.g. robots.txt
), or must retain the exact same file name (without hashing).
Assets placed in public
will be copied to the root of the dist directory as-is.
Note that you should reference files placed in public
using root absolute path - for example, public/icon.png
should always be referenced in source code as /icon.png
.
Base URL
If your site is deployed to a non-root URL, you will need to set the base
option in .vitepress/config.js
. For example, if you plan to deploy your site to https://foo.github.io/bar/
, then base
should be set to '/bar/'
(it should always start and end with a slash).
With a base URL, to reference an image in public
, you'd have to use URLs like /bar/image.png
. But this is brittle if you ever decide to change the base. To help with that, VitePress provides a built-in helper $withBase
(injected onto Vue's prototype) that generates the correct path:
<img :src="$withBase('/foo.png')" alt="foo">
Note you can use the above syntax not only in theme components, but in your Markdown files as well.