Вопрос или проблема
Я знаю, что могу отображать изображение с помощью следующего синтаксиса:
![](/imagepath)
Однако, возможно ли также встраивать изображение непосредственно в документ, чтобы поделиться Markdown документом с изображением, содержащимся прямо внутри него?
Да, это возможно, используя data:
URI и base64. Очень неэффективно, однако:
![Hello World]()
К сожалению, Super User не позволяет data:
URI, это выглядело бы так:
Сработает это, конечно, зависит от того, что вы используете для (пред)просмотра документа. Это должно поддерживать и разрешать data:
URI.
Я провел некоторые тесты, и встраивание обычно работает с онлайн-редакторами markdown, такими как dillinger.io, jbt.github.io, stackedit.io, так что этот вопрос не настолько однозначен, как написал @Spiff выше.
Это снимок экрана двух блоков base64, вставленных с использованием 1) внутренней ссылки и 2) обычной вставки изображения (см. код ниже).
1) указанный base64-блок перестает обрабатываться прямо в том месте, где начинается ‘новый фрагмент изображения’, зеленая часть ... So4Z4wxkXa7KukmKul2dDvd ...
2) при прямой передаче блока мы получаем целое изображение
код
1\)![png тестер1][pngтестер1] 2\)![png тестер2]()
_1\) указанный base64-блок перестает обрабатываться прямо в том месте, где начинается 'новый фрагмент изображения', зеленая часть `... So4Z4wxkXa7KukmKul2dDvd ...`
2\) при прямой передаче блока мы получаем целое изображение_
Это было протестировано с помощью http://tmpvar.com/markdown.html. Я не знаю, как это ведет себя на github. [Вопрос](https://github.com/github/markup/issues/270) уже подробно обсуждался.
[pngтестер1]:
Это было протестировано с http://tmpvar.com/markdown.html. Для поведения на github, вопрос уже подробно обсуждался (и отклонен).
GitHub, markdown-it и Google docs теперь поддерживают встраивание изображений в Markdown.
Самый удобный способ использования этой функции — это ссылка на встроенные изображения, которые будут включены в конец документа:
![Hello World][hello_world_img_base64]
Некоторый другой текст.
[hello_world_img_base64]: <>
Нет, документ Markdown — это просто текстовый файл, и текстовые редакторы (даже те, которые понимают Markdown) не знают, что делать с блоком двоичных данных изображения в середине текстового файла.
Есть такие методы, как MIME и base64, чтобы в некотором смысле кодировать двоичные данные в текстовом файле, но большинство текстовых редакторов и рендереров Markdown не знают, что делать с документом, закодированным в MIME, который содержит часть текста Markdown и часть изображения, закодированного в base64.
.
Ответ или решение
Вопрос о возможности прямого встраивания изображений в документ в формате Markdown вызывает значительный интерес среди пользователей, особенно для тех, кто стремится делиться самодостаточными документами без необходимости прикладывать отдельно файлы изображений. Прежде всего, давайте разберемся в теоретических основах этой возможности.
Теория
Markdown, изначально созданный как легкий язык разметки, предназначен для преобразования текста в различный форматированный контент. Одним из популярных элементов Markdown являются изображения, которые добавляются с помощью синтаксиса ![описание](путь_к_изображению)
. Такой подход подразумевает наличие изображения в вашем файловом хранилище или в сети, и его отображение реализуется путем ссылки на это местоположение.
Однако при рассмотрении вопроса о встраивании изображений непосредственно в текстовую структуру самого Markdown-документа, становится понятно, что Markdown сам по себе не поддерживает хранение бинарных объектов, таких как изображения. Это связано с тем, что Markdown является текстовым форматом, который читается и обрабатывается в основном текстовыми редакторами и не предусматривает операции с бинарными данными.
Пример
Тем не менее, вы можете использовать обходное решение с помощью URI-данных (data URIs) в комбинации с кодированием base64. Этот метод позволяет преобразовать бинарные данные изображения в текстовый формат, который затем можно вставить непосредственно в Markdown-документ. Вот пример, как это может выглядеть:
![Hello World]()
Применение
При использовании данной методики стоит отметить несколько важных моментов. Во-первых, кодирование base64 увеличивает размер файла, что может быть неэффективным при работе с большими изображениями. Во-вторых, не все Markdown-редакторы поддерживают отображение встроенных data URIs, поэтому результат может варьироваться в зависимости от используемого инструмента. Теоретически, браузеры и многие онлайн-редакторы, такие как Dillinger или IT редакторы, могут поддерживать это, однако локальные текстовые редакторы могут испытывать проблемы.
Заключение
С одной стороны, метод с кодированием base64 и использованием data URIs предоставляет возможность встраивания изображений без привязки к внешним ресурсам. С другой стороны, потребление лишнего объема данных и потенциальные несовместимости с различными Markdown-вижуализаторами могут всерьез ограничить практическую ценность этого подхода. Поэтому подобный способ следует рассматривать как дополнительную возможность, а не как основную стратегию работы с изображениями в документах Markdown.