{"id":2762,"date":"2026-01-14T14:20:11","date_gmt":"2026-01-14T05:20:11","guid":{"rendered":"https:\/\/www.earce.biz\/?page_id=2762"},"modified":"2026-01-14T15:26:04","modified_gmt":"2026-01-14T06:26:04","slug":"markdown-viewer","status":"publish","type":"page","link":"https:\/\/www.earce.biz\/?page_id=2762","title":{"rendered":"[Tool] Markdown Viewer"},"content":{"rendered":"\n<p class=\"has-text-align-center wp-block-paragraph\">&lt;&lt; This service is not communicating with the server. &gt;&gt;<\/p>\n\n\n\n<script src=\"https:\/\/cdn.jsdelivr.net\/npm\/marked\/marked.min.js\"><\/script>\n<script src=\"https:\/\/cdn.jsdelivr.net\/npm\/dompurify@3.1.6\/dist\/purify.min.js\"><\/script>\n<script type=\"text\/javascript\">\njQuery().ready(function($){\n\nconst preview = () => {\n  let md = $(\"#textInput\").val();\n  if (md==\"\") {\n    md = $(\"#textInput\").attr(\"placeholder\");\n  }\n  const html = marked.parse(md);\n  const safe = DOMPurify.sanitize(html);\n\n  const iframe = document.getElementById(\"PreviewFrame\");\n  const doc = iframe.contentDocument;\n\n  doc.open();\n  doc.write(`\n    <html>\n      <head>\n        <link rel=\"stylesheet\" href=\"\/pub\/css\/md.css\" \/>\n      <\/head>\n      <body>${safe}<\/body>\n    <\/html>\n  `);\n  doc.close();\n}\n\n$(\"#textInput\").on('input change', preview);\n\npreview();\n});\n<\/script>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Markdown Source<\/strong><\/p>\n\n\n\n<textarea id=\"textInput\" rows=\"5\" cols=\"100\" placeholder=\"# A\n- A-1\n- A-2\n- A-3\n# B\n## B-1\n- B-1-a\n- B-1-b\n## B-2\"><\/textarea>\n\n\n\n<hr class=\"wp-block-separator has-css-opacity\"\/>\n\n\n\n<p class=\"has-medium-font-size wp-block-paragraph\"><strong>Preview<\/strong><\/p>\n\n\n\n<iframe id=\"PreviewFrame\" style=\"width:100%; height:600px; border:1px solid #ccc;\"><\/iframe>\n\n\n\n<p class=\"wp-block-paragraph\"><\/p>\n","protected":false},"excerpt":{"rendered":"<p>&lt;&lt; This service is not communicating with the server. &gt;&gt; Markdown Source Preview<\/p>\n","protected":false},"author":1,"featured_media":0,"parent":35,"menu_order":0,"comment_status":"closed","ping_status":"closed","template":"","meta":{"footnotes":""},"class_list":["post-2762","page","type-page","status-publish","hentry"],"_links":{"self":[{"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/pages\/2762","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/pages"}],"about":[{"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/types\/page"}],"author":[{"embeddable":true,"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.earce.biz\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=2762"}],"version-history":[{"count":28,"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/pages\/2762\/revisions"}],"predecessor-version":[{"id":2790,"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/pages\/2762\/revisions\/2790"}],"up":[{"embeddable":true,"href":"https:\/\/www.earce.biz\/index.php?rest_route=\/wp\/v2\/pages\/35"}],"wp:attachment":[{"href":"https:\/\/www.earce.biz\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=2762"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}