一直使用「马克飞象」写 Markdown, 后来发现了个 Showndown.js 可以渲染 Markdown, 于是就搜了下用法做出了初版一个小网页用来给自己渲染 Markdown 玩玩。不过,后来发现几个瑕疵点,换行对中文不友好,设为 GitHub Flavour 后行尾俩空格就应该是换行,但是这一行有中文的话就不会识别,因此最后找了个替代: marked.js
. (还支持代码高亮哦)
贴出代码:
在线体验:https://youthlin.com/demo/marked.html
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1"> <title>MarkDown Preview</title> <script src="http://cdn.bootcss.com/jquery/2.1.4/jquery.min.js"></script> <script src="http://cdn.bootcss.com/marked/0.3.6/marked.min.js"></script> <script src="http://cdn.bootcss.com/highlight.js/9.9.0/highlight.min.js"></script> <link href='https://dn-maxiang.qbox.me/res-min/themes/marxico.css' rel='stylesheet'> <style type="text/css"> html, body{height: 100%;} #content, #result{ width: 100%; max-width: 100%; min-width: 100%; height: 50%; max-height: 50%; min-height: 50%; padding: 1%; } #content{resize: none;} textarea:focus { box-shadow: 0 0 5px rgba(81, 203, 238, 1); border: 1px solid rgba(81, 203, 238, 1); } #result{ overflow-x: hidden; overflow-y: auto; float: right; /*font-family:"Palatino Linotype","Book Antiqua","Microsoft YaHei",STXihei,Palatino,serif;*/ } @media screen and (min-width: 768px){ #content, #result{ height: 100%; max-height: 100%; min-height: 100%; width: 50%; max-width: 50%; min-width: 50%; } } .hljs{display:block;overflow-x:auto;padding:0.5em;background:#F0F0F0}.hljs,.hljs-subst{color:#444}.hljs-comment{color:#888888}.hljs-keyword,.hljs-attribute,.hljs-selector-tag,.hljs-meta-keyword,.hljs-doctag,.hljs-name{font-weight:bold}.hljs-type,.hljs-string,.hljs-number,.hljs-selector-id,.hljs-selector-class,.hljs-quote,.hljs-template-tag,.hljs-deletion{color:#880000}.hljs-title,.hljs-section{color:#880000;font-weight:bold}.hljs-regexp,.hljs-symbol,.hljs-variable,.hljs-template-variable,.hljs-link,.hljs-selector-attr,.hljs-selector-pseudo{color:#BC6060}.hljs-literal{color:#78A960}.hljs-built_in,.hljs-bullet,.hljs-code,.hljs-addition{color:#397300}.hljs-meta{color:#1f7199}.hljs-meta-string{color:#4d99bf}.hljs-emphasis{font-style:italic}.hljs-strong{font-weight:bold} </style> </head> <body> <div style="height: 100%;"> <div id="result"></div> <textarea id="content" onkeyup="compile()" autofocus># Markdown Preview >请在此处键入 `markdown` 内容 右侧将会_自动_生成预览。 ``` System.out.println("Please input markdown text here."); ``` </textarea> </div> <script type="text/javascript"> var render = new marked.Renderer(); marked.setOptions({ renderer: render, //指定渲染器 gfm: true, // GitHub 风格 tables: true, //支持表格 breaks: true, //回车换成br pedantic: false, sanitize: true, smartLists: true, smartypants: false, highlight:function (code) { //代码高亮 return hljs.highlightAuto(code).value; } }); function compile(){//编译渲染 $('#result').html(marked($("#content").val())); } var $divs = $('textarea#content, div#result'); var sync = function(e){//同步滚动 var $other = $divs.not(this).off('scroll'), other = $other.get(0); var percentage = this.scrollTop / (this.scrollHeight - this.offsetHeight); other.scrollTop = percentage * (other.scrollHeight - other.offsetHeight); setTimeout( function(){ $other.on('scroll', sync ); },200); } $(document).ready(function(){ $divs.on('scroll', sync); compile();//页面加载后编译一次 }); </script> </body> </html>
一看就懂就不需要解释了吧~~
效果预览:
// jQuery 对象和 DOM 对象以前不太清除,现在写起 jQuery 来查了下知道了, jQuery 对象是 jQuery 自己的,和原生 js 没有很大关系,它有很多简单名字的方法,如.html()
. 而 DOM 对象是原生 js 的,属性和方法一大堆不好记,如 innerHTML
. 所以有人写 jQuery 时会在 jQuery 对象命名时用 $ 美元符号作为前缀。
// js 中变量是否有 var 声明:在函数外,不管有没有 var 都是全局变量;在函数内,有 var 的变量时局部变量,否则是全局变量。
在线体验:https://youthlin.com/demo/marked.html
声明
- 本作品采用署名-非商业性使用-相同方式共享 4.0 国际许可协议进行许可。除非特别注明, 霖博客文章均为原创。
- 转载请保留本文(《使用 JS 预览 Markdown》)链接地址: https://youthlin.com/?p=1395
- 订阅本站:https://youthlin.com/feed/
“使用 JS 预览 Markdown”上的11条回复
markdown要多用,否则要经常查资料,现在简书上操练着。
学长求脸熟【火前刘明
并没有熟:不知道名字。
这么巧,估计也是你写这个博文那时候左右,我也挂我博客上一个,来来来,拼一下效果:http://he.xcy.me/user/themes/xcyam/assets/md2html.html
还是你厉害
CSS 很漂亮,不过我发现:
1. 输入时结果会随着按键闪动
2. 不识别有序列表
3. 代码没有高亮
4. 我这里写的还有同步滚动/Web自适应哦
test case:
1 输入闪动确切意思没懂。因为是实时改写内容来呈现效果,自然会闪动呀
2 识别有序列表,可能是从外观样式看不出来罢了。你可以双击效果文字使它显示HTML源标标记(设置的一个隐藏开关)
3 代码确实不高亮,这样可以减小Javascript文件大小,适合放置于自己博客上
4 自适应确实不太会,但是我也有考量,我的想法是宽度100%,上下分隔用比例,当为手机等不同长宽比显示时可以较好显现视口,用chrome仿真屏幕看没问题。自动滚动上也是最简方案,当效果呈现区内容较多后在MD里继续输入则效果区总是滚动至最底层来显示新输入内容
嗯嗯 这样说来你这个真的很棒哦!双击显示源代码这个赞 我都没发现
你下次来还会发现另一点
指正个鬼啊,根本不能评论
啊。我博客没有评论功能。但是我可以霸占你的评论区啊,你看,你给我的评论我不是可以在这里给你回复。