É possível incorporar diretamente uma imagem em um documento Markdown?

25

Eu sei que posso exibir uma imagem com a seguinte sintaxe:

![](/imagepath)

No entanto, também é possível incorporar diretamente uma imagem no documento para compartilhar o documento Markdown com o arquivo de imagem contido diretamente nele?

orschiro
fonte

Respostas:

36

Sim, é possível, usando data:URIs e base64. Terrivelmente ineficiente:

![Hello World]()

Infelizmente Super User não permite data:URIs, ficaria assim:

insira a descrição da imagem aqui

Se isso vai funcionar, é claro, depende do que você está usando para (pré) visualizar o documento. Tem que suportar e permitir data:URIs.

Daniel B
fonte
Muito interessante, obrigado! Você conhece algum editor do Markdown que possa interpretar e exibir este formato?
orschiro
2
@orschiro Infelizmente não, desculpe. Acabei de escrever Markdown à mão. No entanto, em teoria, qualquer editor que "compila" o documento para HTML e exibe o que deve fazer.
Daniel B
5
Talvez valha a pena acrescentar que, se você usar a " Sintaxe de imagem no estilo de referência ", poderá pelo menos enterrar o código base64 na parte inferior da sua página de Markdown. ![My image up in the page][1]seguido em algum ponto por[1]: ...
ruffin
Parece correto na sintaxe. Mas alguns serviços vão lidar com isso incorretamente (como o wiki do Github, por exemplo)
CarlosCarucce
2

Não, um documento do Markdown é apenas um arquivo de texto, e os editores de texto (mesmo os que usam o Markdown) não saberiam o que fazer com um blob de dados de imagens binárias no meio de um arquivo de texto.

Existem métodos como MIME e base64 para codificar dados binários em um arquivo de texto em um sentido, mas a maioria dos editores de texto e renderizadores do Markdown não saberiam o que fazer com um documento codificado em MIME que contenha uma parte de texto Markdown e uma imagem codificada em base64 parte.

Spiff
fonte
0

Eu fiz alguns testes e incorporação geralmente funciona com editores de marcação on-line como dillinger.io, jbt.github.io, stackedit.io , então este tópico não é tão preto e branco como @Spiff escreveu acima.

Esta é uma captura de tela de dois blocos base64 inseridos usando 1) uma referência interna e 2) uma inserção de imagem comum (veja o código abaixo).

pngtesters

1) o bloco base64 referenciado deixa de ser analisado no ponto onde começa 'um novo pedaço de imagem', a parte verde ... So4Z4wxkXa7KukmKul2dDvd ...
2) passando o bloco diretamente obtemos toda a imagem

código

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]:

Isso foi testado com http://tmpvar.com/markdown.html . Eu não sei como isso se comporta no github. A questão já foi bem discutida.

zer0mode
fonte