图片
大约 2 分钟
改进 Markdown 中的图像语法以支持颜色方案和大小。
配置
TS
// .vuepress/config.ts
import { defineUserConfig } from "vuepress";
import { hopeTheme } from "vuepress-theme-hope";
export default defineUserConfig({
theme: hopeTheme({
plugins: {
mdEnhance: {
// 启用 figure
figure: true,
// 启用图片懒加载
imgLazyload: true,
// 启用图片标记
imgMark: true,
// 启用图片大小
imgSize: true,
},
},
}),
});
JS
/// .vuepress/config.js
import { hopeTheme } from "vuepress-theme-hope";
export default {
theme: hopeTheme({
plugins: {
mdEnhance: {
// 启用 figure
figure: true,
// 启用图片懒加载
imgLazyload: true,
// 启用图片标记
imgMark: true,
// 启用图片大小
imgSize: true,
},
},
}),
};
图片懒加载
如果你想在你的页面中延迟加载图片,你可以在插件选项中设置 imgLazyload: true
。
注
我们正在使用原生 HTML5 功能启用延迟加载,因此你的浏览器必须支持 loading=lazy 属性。
图片 ID 标记
GFM 支持通过 ID 标记图片,使得图片只在特定的模式显示。我们同时支持 GitHub 的标记与简易标记 #light
和 #dark
。
你可以通过主题选项中的 plugins.mdEnhance.imgMark
选项控制它。
data:image/s3,"s3://crabby-images/712f3/712f30b404ae1caca6fa11fc72ed554d6b2cb887" alt="GitHub Light"
data:image/s3,"s3://crabby-images/eda4a/eda4a309614d043a713624b868a7302da41d1e69" alt="GitHub Dark"
data:image/s3,"s3://crabby-images/c9854/c9854a6416c03fd6275c4f1e38fd9501c6f1322f" alt="GitHub Light"
data:image/s3,"s3://crabby-images/f23bd/f23bd2f10ee1863b5103d0613a5f1f0f60cbcb51" alt="GitHub Dark"
高级用法
你可以将对象传递给 imgMark
以配置 ID 标记,可用选项有:
interface ImageMarkOptions {
/** 仅限日间模式的 ID */
light?: string[];
/** 仅限夜间模式的 ID */
dark?: string[];
}
图片尺寸
当你在主题选项中设置 plugin.mdEnhance.imgSize: true
时,可以使用 =widthxheight
指定图像大小。
data:image/s3,"s3://crabby-images/11bd0/11bd07091fd3b9060fa49c67bd5048b4939f4595" alt="Alt"
data:image/s3,"s3://crabby-images/6a2c4/6a2c4f2d860e3eb58342e3a64a148cc9083324a6" alt="Alt"
data:image/s3,"s3://crabby-images/844b9/844b9412443bff09c19fdc2e3a0fe5cb46e4d829" 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: true
。
这样当你单独将图片至于一行 (也可同时嵌套链接),图像将显示为 <figure>
,标题或图片替代文字将显示为 <figcaption>
。
data:image/s3,"s3://crabby-images/ba777/ba777c8861029bde42315b9a5257bdaa61348df9" alt="VuePress Hope 图标"
[data:image/s3,"s3://crabby-images/ba777/ba777c8861029bde42315b9a5257bdaa61348df9" alt="VuePress Hope 图标"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/b19a2/b19a2019f15a67f05e90cde2cc94b52f7b3c7475" alt="VuePress Hope 图标"
[data:image/s3,"s3://crabby-images/b19a2/b19a2019f15a67f05e90cde2cc94b52f7b3c7475" alt="VuePress Hope 图标"](https://theme-hope.vuejs.press/)
data:image/s3,"s3://crabby-images/0b6d3/0b6d3b8625d4b459fc1ce3353ecc2d9238a25cc9" alt="VuePress Hope 图标"
将呈现为: