是否可以将图像直接嵌入到 Markdown 文档中?

是否可以将图像直接嵌入到 Markdown 文档中?

我知道我可以使用以下语法显示图像:

![](/imagepath)

但是,是否也可以直接将图像嵌入到文档中,以便共享包含图像文件的 Markdown 文档?

答案1

是的,可以,使用data:URI和 base64。但是效率极低:

![Hello World]()

不幸的是超级用户不允许data:使用 URI,它看起来像这样:

在此处输入图片描述

当然,这是否可行取决于您使用什么来(预)查看文档。它必须支持并允许data:URI。

答案2

我做了一些测试,嵌入通常适用于在线 Markdown 编辑器,例如dillinger.io、jbt.github.io、stackedit.io,所以这个话题并不像@Spiff 上面写的那样黑白分明。

这是使用以下代码插入两个 base64 块的屏幕截图1)内部参考和2)常见的图像插入(见下面的代码)。

pngtesters

1)引用的 base64 块在“新图像块”开始的地方停止解析,即绿色部分... So4Z4wxkXa7KukmKul2dDvd ...
2)通过直接传递该块,我们得到了整个图像

代码

1\)![png tester1][pngtester1] 2\)![png tester2]()

_1\) the referenced base64 block stops being parsed right at the point where 'a new chunk of image' starts, the green part `... So4Z4wxkXa7KukmKul2dDvd ...`  
2\) by passing the block directly we get the whole image_

This was tested with http://tmpvar.com/markdown.html. I don't know how it behaves on github. [The issue](https://github.com/github/markup/issues/270) has been already well discussed.

[pngtester1]:

经过测试http://tmpvar.com/markdown.html. 对于 github 上的行为,问题已经得到充分讨论(并被拒绝)。

答案3

不,Markdown 文档只是一个文本文件,文本编辑器(即使是熟悉 Markdown 的编辑器)也不知道如何处理文本文件中间的一团二进制图像数据。

从某种意义上说,有像 MIME 和 base64 这样的方法将二进制数据编码为文本文件,但大多数文本编辑器和 Markdown 渲染器不知道如何处理包含 Markdown 文本部分和 base64 编码图像部分的 MIME 编码文档。

相关内容