生成带有markdown引用的base64编码的图像字符串

chenyajun  2022-10-16 13:55:19  阅读 1129 次 评论 0 条
<!DOCTYPE html>    <html lang="en">    <head>    <meta charset="UTF-8" />    <meta name="viewport" content="width=device-width, initial-scale=1" />    <title>Paste to base64</title>    <link    rel="stylesheet"    href="https://cdnjs.cloudflare.com/ajax/libs/foundation/6.5.3/css/foundation.min.css"    />    <style>    
      .container {    
        margin: 0 auto;    
        width: 960px;    
      }    
      textarea {    
        display: block;    
        width: 100%;    
        height: 618px;    
      }    
    </style>    </head>    <body>    <div class="grid-container">    <h1>Paste to base64</h1>    <div class="grid-x grid-margin-x">    <div class="cell small-6">    <h3>Raw Base64</h3>    <label>    <b>base64</b>    <textarea name="base64TextArea"></textarea>    </label>    </div>    <div class="cell small-6">    <h3>Base64 for Markdown</h3>    <label>    <b>Example in Markdown</b>    <div class="callout">    <ol>    <li>    Embed the base64 image to the document (ideally, at the end of    
the document)    
<div class="callout">    <code>[abc]:data:image/png;base64,iVBORw0KGgoA...</code>    </div>    </li>    <li>    Refer to embedded base64's named reference of <code>abc</code>    <div class="callout">    <code>![abc] lorem ipsum dolor</code>    </div>    </li>    </ol>    </div>    </label>    <label>    <b>Markdown Reference Name</b>    <input type="text" name="markdownReferenceName" />    </label>    <label>    <b>Embedded Markdown Base64 Reference</b>    <button    type="button"    class="button"    name="copyButton"    onclick="handleCopyButton()"    >    Copy    
</button>    <textarea name="base64TextAreaForMarkdown"></textarea>    </label>    </div>    </div>    </div>    </body>    <script type="text/javascript">    
    function handleCopyButton(event) {    
      const base64TextArea = document.getElementsByName(    
        "base64TextAreaForMarkdown"    
      )[0];    
      base64TextArea.select();    
      document.execCommand("copy");    
    }    
    function onPasteHandler({ clipboardData, originalEvent }) {    
      const base64TextArea = document.getElementsByName("base64TextArea")[0];    
      const base64TextAreaForMarkdown = document.getElementsByName(    
        "base64TextAreaForMarkdown"    
      )[0];    
      const markdownReferenceName = document.getElementsByName(    
        "markdownReferenceName"    
      )[0];    
      if (!markdownReferenceName.value) {    
        alert("Must provide a reference name first");    
        markdownReferenceName.focus();    
        return;    
      }    
      const clipboard = clipboardData || originalEvent.clipboardData;    
      const items = clipboard.items;    
      // update the base64 embedded markdown reference with new markdown reference name    
      markdownReferenceName.onchange = function(event) {    
        const { value } = event.currentTarget;    
        const currentBase64 = base64TextArea.value;    
        base64TextAreaForMarkdown.innerText = `[${value}]:${currentBase64}`;    
      };    
      const item = items[0];    
      if (item.kind === "file") {    
        const blob = item.getAsFile();    
        const reader = new FileReader();    
        reader.onload = ({ target }) => {    
          base64TextArea.innerText = target.result;    
          const markdownReferenceNameValue = markdownReferenceName.value;    
          base64TextAreaForMarkdown.innerText = `[${markdownReferenceNameValue}]:${    
            target.result    
          }`;    
        };    
        reader.readAsDataURL(blob);    
      }    
    }    
    document.onpaste = onPasteHandler;    
  </script>    </html>


本文地址:http://chenyajun.net/index.php/post/103.html
版权声明:本文为原创文章,版权归 chenyajun 所有,欢迎分享本文,转载请保留出处!

评论已关闭!