Markdown.css 是一个很有意思的 CSS 样式表。它可以让 HTML 显示成类似 Markdown 纯文本的形式。

Markdown.css样式简介

基于 LESS 编写

Markdown.css 基于 LESS 编写,源代码在此。

下面简要地解析一下具体实现的方法。
标题

markdown 的标题在前加上 # 到 ###### 表示。这是用了 CSS 的伪类 :before 实现,例如 h2 是这么定义的:

CSS Code复制内容到剪贴板
  1. h2:before {   
  2.   content: "## ";   
  3.   display: inline;   
  4. }  

强调

强调是前后加上*,因此除了 :before 之外还用到了 :after。

CSS Code复制内容到剪贴板
  1. @em-char: "*";   
  2. em:before, em:after {   
  3.   content: @em-char;   
  4.   display: inline;   
  5. }  

strong、code的实现类似。
链接

Markdown 中的链接采用 [text](link) 的格式,实现和上面的强调的做法类似,首先去掉文本的装饰,然后使用 :before 在前面添加 [:

CSS Code复制内容到剪贴板
  1. a {   
  2.   text-decoration: none;   
  3. }   
  4. a:before {   
  5.   content: "[";   
  6.   display: inline;   
  7.   color: @color;   
  8. }  

后面添加的内容中包含链接,可以通过 attr(href) 取得:

CSS Code复制内容到剪贴板
  1. a:after {   
  2.   content: ~'"](" attr(href) ")"';   
  3.   display: inline;   
  4.   color: @color;   
  5. }  

pre

pre 的话,很简单,只要左边缩进四个字符即可。对于支持缩进四个字符的浏览器,使用4ch即可,不支持的浏览器那就使用34px。

CSS Code复制内容到剪贴板
  1. @four-space: 34px;   
  2. @four-space-css3: ~"4ch";    
  3. pre {   
  4.   margin-left: @four-space;   
  5.   padding-left: @four-space-css3;   
  6. }  

引用

Markdown 中的引用采用如下格式:

> 这是一个引用
> 引用的第二行

因此,采用的方法是在引用后添加>和 \A (换行),然后调整位置,使其与原文“对齐”,并隐藏多余的>。

CSS Code复制内容到剪贴板
  1. blockquote {   
  2.   position: relative;   
  3.   padding-left: @four-space/2;   
  4.   padding-left: @two-space-css3;   
  5.   overflow: hidden;   
  6.   
  7.   &:after {   
  8.       // 100 lines max   
  9.       // the \A becomes a newline character and `whitewhite-space: pre`   
  10.       // makes it act like a <br>   
  11.       content: ">\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>\A>";   
  12.       whitewhite-space: pre;   
  13.       position: absolute;   
  14.       top: 0;   
  15.       left: 0;   
  16.       font-size: @font-size;   
  17.       line-height: @line-height;   
  18.   }   
  19. }  

图片

使用如下 CSS 可以实现图片转为 markdown 形式显示:

CSS Code复制内容到剪贴板
  1. img { content: "" }    
  2.   
  3. img:before {   
  4.  content: "![";   
  5.  color: #333333;   
  6. }   
  7.   
  8. img:after {   
  9.  content: "](" attr(src) ")";   
  10.  color: #333333;   
  11. }  

markdownify

还有一个 markdownify 的 bookmarklet,将其保存在书签栏之后,可以将任意网站转为 Markdown 样式。


CSS Code复制内容到剪贴板
  1. $('link[rel=stylesheet]').add('style').remove();   
  2. $('[style]').attr('style', '');   
  3. $('head').append('<link rel="stylesheet" href="http://mrcoles.com/media/test/markdown-css/markdown.css" type="text/css" />');   
  4. $('body').addClass('markdown').css({width: '600px', margin: '2em auto', 'word-wrap': 'break-word'});   
  5. $('a img').css({'max-height': '1em', 'max-width': '1em'});  

 

标签:
Markdown,CSS

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
评论“Markdown.css样式简介”
暂无“Markdown.css样式简介”评论...

《魔兽世界》大逃杀!60人新游玩模式《强袭风暴》3月21日上线

暴雪近日发布了《魔兽世界》10.2.6 更新内容,新游玩模式《强袭风暴》即将于3月21 日在亚服上线,届时玩家将前往阿拉希高地展开一场 60 人大逃杀对战。

艾泽拉斯的冒险者已经征服了艾泽拉斯的大地及遥远的彼岸。他们在对抗世界上最致命的敌人时展现出过人的手腕,并且成功阻止终结宇宙等级的威胁。当他们在为即将于《魔兽世界》资料片《地心之战》中来袭的萨拉塔斯势力做战斗准备时,他们还需要在熟悉的阿拉希高地面对一个全新的敌人──那就是彼此。在《巨龙崛起》10.2.6 更新的《强袭风暴》中,玩家将会进入一个全新的海盗主题大逃杀式限时活动,其中包含极高的风险和史诗级的奖励。

《强袭风暴》不是普通的战场,作为一个独立于主游戏之外的活动,玩家可以用大逃杀的风格来体验《魔兽世界》,不分职业、不分装备(除了你在赛局中捡到的),光是技巧和战略的强弱之分就能决定出谁才是能坚持到最后的赢家。本次活动将会开放单人和双人模式,玩家在加入海盗主题的预赛大厅区域前,可以从强袭风暴角色画面新增好友。游玩游戏将可以累计名望轨迹,《巨龙崛起》和《魔兽世界:巫妖王之怒 经典版》的玩家都可以获得奖励。