क्या किसी मार्कडाउन दस्तावेज़ में सीधे छवि को एम्बेड करना संभव है?


31

मुझे पता है कि मैं निम्नलिखित सिंटैक्स के साथ एक छवि प्रदर्शित कर सकता हूं:

![](/imagepath)

हालाँकि, क्या यह भी संभव है कि मार्कडाउन डॉक्यूमेंट को सीधे इमेज फाइल के साथ साझा करने के लिए डॉक्यूमेंट में एक इमेज को सीधे इनसाइड करें?

जवाबों:


44

हां, यह संभव है, data:URI और base64 का उपयोग करना । हालांकि बहुत अक्षम है:

![Hello World]()

दुर्भाग्य से सुपर उपयोगकर्ता data:URIs की अनुमति नहीं देता है, यह इस तरह दिखेगा:

यहां छवि विवरण दर्ज करें

क्या यह निश्चित रूप से काम करेगा, इस बात पर निर्भर करता है कि आप जो भी उपयोग कर रहे हैं (पूर्व) दस्तावेज़ देखें। इसे data:यूआरआई का समर्थन और अनुमति देनी होगी ।


बहुत दिलचस्प है, धन्यवाद! क्या आप किसी भी लोकप्रिय मार्कडाउन संपादकों के बारे में जानते हैं जो इस प्रारूप की व्याख्या और प्रदर्शन कर सकते हैं।
ओशोइरो

2
@orschiro दुर्भाग्य से नहीं, क्षमा करें। मैं सिर्फ हाथ से मार्कडाउन लिखता हूं। हालांकि, सिद्धांत रूप में, कोई भी संपादक जो HTML को दस्तावेज़ को "संकलित" करता है और प्रदर्शित करता है कि उसे करना चाहिए।
डैनियल बी

5
शायद यह जोड़ने के लायक है कि यदि आप " संदर्भ-शैली की छवि सिंटैक्स " का उपयोग करते हैं , तो आप कम से कम बेस 64 कोड को अपने मार्कडाउन पेज के नीचे दफन कर सकते हैं। ![My image up in the page][1]इसके बाद कुछ बिंदु पर[1]: ...
रफिन

सिंटेक्स पर सही लगता है। लेकिन कुछ सेवाएं इसे गलत तरीके से संभालेंगी (उदाहरण के लिए,
गितुब

2

नहीं, एक मार्कडाउन डॉक्यूमेंट सिर्फ एक टेक्स्ट फाइल है, और टेक्स्ट एडिटर (यहां तक ​​कि मार्कडाउन-सेवी वाले) को यह नहीं पता होगा कि टेक्स्ट फाइल के बीच में बाइनरी इमेज डेटा के ब्लॉब के साथ क्या करना है।

बाइनरी डेटा को एक अर्थ में बाइनरी डेटा को एनकोड करने के लिए MIME और base64 जैसे तरीके हैं, लेकिन ज्यादातर टेक्स्ट एडिटर्स और मार्कडाउन-रेंडरर्स को यह पता नहीं होगा कि MIME एनकोडेड डॉक्यूमेंट के साथ क्या करना है जिसमें एक मार्कडाउन टेक्स्ट पार्ट और एक बेस 64 कोडेड इमेज शामिल है अंश।


0

मैंने कुछ परीक्षण किए और एम्बेडिंग आमतौर पर ऑनलाइन मार्कडाउन संपादकों जैसे कि dillinger.io, jbt.github.io, stackedit.io के साथ काम करता है , इसलिए यह विषय इतना काला और सफेद नहीं है जैसा कि @Spiff ने ऊपर लिखा है।

इस का उपयोग कर डाला दो बेस 64 ब्लॉक के एक स्क्रीनशॉट है 1) एक आंतरिक संदर्भ और 2) एक आम छवि प्रविष्टि (नीचे दिए गए कोड को देखें)।

pngtesters

1) संदर्भित बेस 64 ब्लॉक ठीक उस बिंदु पर पार्स किया जा रहा है जहाँ 'छवि का एक नया हिस्सा' शुरू होता है, हरे भाग ... 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 के साथ परीक्षण किया गया था । मुझे नहीं पता कि यह गीथब पर कैसे व्यवहार करता है। इस मुद्दे पर पहले ही चर्चा हो चुकी है।

हमारी साइट का प्रयोग करके, आप स्वीकार करते हैं कि आपने हमारी Cookie Policy और निजता नीति को पढ़ और समझा लिया है।
Licensed under cc by-sa 3.0 with attribution required.