markdown-image
Add additional features to your markdown images.
Usage
npm i -D @vuepress/plugin-markdown-image@next
import { markdownImagePlugin } from '@vuepress/plugin-markdown-image'
export default {
plugins: [
markdownImagePlugin({
// Enable figure
figure: true,
// Enable image lazyload
lazyload: true,
// Enable image mark
mark: true,
// Enable image size
size: true,
}),
],
}
Guide
Image Lazyload
The plugin will enable image lazyload using native HTML5 features, so only it's only working on browsers which support loading=lazy attribute.
Image Mark
When you set mark: true
in plugin options, you can mark pictures by #light
and #dark
suffix to let them be displayed under certain color mode.
data:image/s3,"s3://crabby-images/cc065/cc0656ca16edccd11d2dcd743a3bc8a4d45061d5" alt="GitHub Light"
data:image/s3,"s3://crabby-images/eac26/eac2606f5625b901c73bdc8312afde8a432bf300" alt="GitHub Dark"
Advanced
You can pass an object to mark
to config ID marks, available options are:
interface ImageMarkOptions {
/** lightmode only IDs */
light?: string[]
/** darkmode only IDs */
dark?: string[]
}
Image Size
You can use =widthxheight
to specify the image size when setting size: true
in plugin options.
data:image/s3,"s3://crabby-images/07ecb/07ecb2155be60877897482214a5a967ae0209ae5" alt="Alt"
data:image/s3,"s3://crabby-images/7ecb5/7ecb5aa27df4808d127ef05121ddd3fa25e46920" alt="Alt"
data:image/s3,"s3://crabby-images/8b53c/8b53cf9062534df6f6d4bd4046e15982ece7cef4" alt="Alt"
The above Markdown will be parsed as:
<img src="/example.png" width="200" height="300" />
<img src="/example.jpg" title="Image title" width="200" />
<img src="/example.bmp" height="300" />
Figure Display
Sometimes, you may want to add a description with image and place it between contents, in this case you should set figure: true
in plugin options.
If the image is standalone in a line, wrapped or not wrapped by link, it will be displayed as <figure>
and title (or alt) will be displayed as <figcaption>
.
data:image/s3,"s3://crabby-images/06694/06694d816a75c0f2cdc7edfa7e1ab6855fa60f9a" alt="VuePress Logo"
data:image/s3,"s3://crabby-images/ae16f/ae16f96403d48c217f5e62eb314d0a922b4c62a0" alt="VuePress Logo"
[data:image/s3,"s3://crabby-images/ae16f/ae16f96403d48c217f5e62eb314d0a922b4c62a0" alt="VuePress Logo"](https://vuejs.press/)
data:image/s3,"s3://crabby-images/6b8c3/6b8c34684cae9895bfd223e8f66c10a453feedf3" alt="VuePress Logo"
[data:image/s3,"s3://crabby-images/6b8c3/6b8c34684cae9895bfd223e8f66c10a453feedf3" alt="VuePress Logo"](https://vuejs.press/)
data:image/s3,"s3://crabby-images/3b1ab/3b1ab19e8ef1dccedee470f0d3c1f4d714198e56" alt="VuePress Logo"
Options
figure
- Type:
boolean
- Details: Whether enable figure support.
lazyload
- Type:
boolean
- Details: Whether to lazy load every image in page in native way.
mark
Type:
ImageMarkOptions | boolean
interface ImageMarkOptions { /** lightmode only IDs */ light?: string[] /** darkmode only IDs */ dark?: string[] }
Details: Whether enable image mark support.
size
- Type:
boolean
- Details:
Whether enable image size support.
obsidianSize
- Type:
boolean
- Details: Whether enable Obsidian image size support.