Image
Improve image syntax in Markdown to support color scheme and size.
Settings
import { defineUserConfig } from "vuepress";
import { hopeTheme } from "vuepress-theme-hope";
export default defineUserConfig({
theme: hopeTheme({
markdown: {
// Enable figure
figure: true,
// Enable image lazyload
imgLazyload: true,
// Enable image mark
imgMark: true,
// Enable image size
imgSize: true,
},
}),
});
Image Lazyload
This feature enables lazyload with native HTML5, so your browser must support loading=lazy attribute.
Image Mark
This feature allows you to mark images with #light
and #dark
suffix to display them in a specific color scheme.
data:image/s3,"s3://crabby-images/d336a/d336aab63df3ba826e95f5a07c5cd270db4211ab" alt="GitHub Light"
data:image/s3,"s3://crabby-images/43a44/43a444d869de3191c12b49ca7673afa44ae1b1e3" alt="GitHub Dark"
Advanced
You can pass an object to markdown.imgMark
to config ID marks:
import { defineUserConfig } from "vuepress";
import { hopeTheme } from "vuepress-theme-hope";
export default defineUserConfig({
theme: hopeTheme({
markdown: {
imgMark: {
/** lightmode only IDs */
light: ["light"],
/** darkmode only IDs */
dark: ["dark"],
},
},
}),
});
Image Size
You can use =widthxheight
to specify the image size with this feature.
data:image/s3,"s3://crabby-images/40b4e/40b4e72915e6a64af49eee7425a7f5e5312136e0" alt="Alt"
data:image/s3,"s3://crabby-images/73518/735183cc885b33cbdb12ce9fce864536d445e1da" alt="Alt"
data:image/s3,"s3://crabby-images/df54e/df54edd378d25f66cf7a148f25ef4019d0c5039b" 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
Sometimes, you may want to add a description with image and place it between contents, in this case you should use this feature to convert images to <figure>
.
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/53e2d/53e2da39794e0190df333486e0f8d81f7924aaf7" alt="VuePress Hope Logo"
[data:image/s3,"s3://crabby-images/53e2d/53e2da39794e0190df333486e0f8d81f7924aaf7" alt="VuePress Hope Logo"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/1b8fb/1b8fb7666f9eab79a3cef0da82406870b45e175d" alt="VuePress Hope Logo"
[data:image/s3,"s3://crabby-images/1b8fb/1b8fb7666f9eab79a3cef0da82406870b45e175d" alt="VuePress Hope Logo"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/a5727/a57274129885ea06eec8d75a1a84f582532f79ed" alt="VuePress Hope Logo"