图片
大约 2 分钟
改进 Markdown 中的图像语法以支持颜色方案和大小。
配置
import { defineUserConfig } from "vuepress";
import { hopeTheme } from "vuepress-theme-hope";
export default defineUserConfig({
theme: hopeTheme({
markdown: {
// 启用 figure
figure: true,
// 启用图片懒加载
imgLazyload: true,
// 启用图片标记
imgMark: true,
// 启用图片大小
imgSize: true,
},
}),
});
图片懒加载
此功能通过原生 HTML5 启用图片的延迟加载,因此仅在 支持 loading=lazy 属性 的浏览器生效。
图片 ID 标记
此功能允许你通过 #light
和 #dark
标记图片,使得图片只在特定的模式显示。
图片 ID 标记示例
👈 尝试切换主题
<ColorModeSwitch /> 👈 尝试切换主题
data:image/s3,"s3://crabby-images/d336a/d336aab63df3ba826e95f5a07c5cd270db4211ab" alt="GitHub Light"
data:image/s3,"s3://crabby-images/43a44/43a444d869de3191c12b49ca7673afa44ae1b1e3" alt="GitHub Dark"
高级用法
你可以将对象传递给 markdown.imgMark
以配置 ID 标记:
import { defineUserConfig } from "vuepress";
import { hopeTheme } from "vuepress-theme-hope";
export default defineUserConfig({
theme: hopeTheme({
markdown: {
imgMark: {
/** 仅限日间模式的 ID */
light: ["light"],
/** 仅限夜间模式的 ID */
dark: ["dark"],
},
},
}),
});
图片尺寸
通过此功能,你可以使用 =widthxheight
指定图像大小。
data:image/s3,"s3://crabby-images/40b4e/40b4e72915e6a64af49eee7425a7f5e5312136e0" alt="Alt"
data:image/s3,"s3://crabby-images/b45d6/b45d63b5c94539e14f4f5cd2d949474678c72750" alt="Alt"
data:image/s3,"s3://crabby-images/df54e/df54edd378d25f66cf7a148f25ef4019d0c5039b" alt="Alt"
上面的 Markdown 将被解析为:
<img src="/example.png" width="200" height="300" />
<img src="/example.jpg" title="图片标题" width="200" />
<img src="/example.bmp" height="300" />
图片展示
有时,你可能希望为图像添加描述,并将其单独展示在上下文中,在这种情况下,你应该启用此功能将图片渲染为 <figure>
。
这样当你单独将图片至于一行 (也可同时嵌套链接),图像将显示为 <figure>
,标题或图片替代文字将显示为 <figcaption>
。
图片示例 demo
data:image/s3,"s3://crabby-images/53e2d/53e2da39794e0190df333486e0f8d81f7924aaf7" alt="VuePress Hope 图标"
[data:image/s3,"s3://crabby-images/53e2d/53e2da39794e0190df333486e0f8d81f7924aaf7" alt="VuePress Hope 图标"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/c05a5/c05a5d601980e315d72bdb08e964e824efeaa449" alt="VuePress Hope 图标"
[data:image/s3,"s3://crabby-images/c05a5/c05a5d601980e315d72bdb08e964e824efeaa449" alt="VuePress 图标"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/331a0/331a047acbf28b1740a6ad60d0893787248c68b6" alt="VuePress Hope 图标"