Markdown.css样式简介

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

基于 LESS 编写

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

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

标题

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

CSS Code复制内容到剪贴板 h2:before {      content"## ";      displayinline;    }  

强调

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

CSS Code复制内容到剪贴板 @em-char: "*";    em:before, em:after {      content: @em-char;      displayinline;    }  

h3、code的实现类似。

链接

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

CSS Code复制内容到剪贴板 a {      text-decorationnone;    }    a:before {      content"[";      displayinline;      color: @color;    }  

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

CSS Code复制内容到剪贴板 a:after {      content: ~"](" attr(href) ")";      displayinline;      color: @color;    }  

pre

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

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

引用

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

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

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

CSS Code复制内容到剪贴板 blockquote {      positionrelative;      padding-left: @four-space/2;      padding-left: @two-space-css3;      overflowhidden;         &:after {          // 100 lines max          // the A becomes a newline character and `whitewhite-spacepre`          // makes it act like a <br>          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>";          whitewhite-spacepre;          positionabsolute;          top: 0;          left: 0;          font-size: @font-size;          line-height: @line-height;      }    }  

图片

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

CSS Code复制内容到剪贴板 img { content"" }        img:before {     content"![";     color#333333;    }       img:after {     content"](" attr(src")";     color#333333;    }  

markdownify

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


CSS Code复制内容到剪贴板 $(link[rel=stylesheet]).add(style).remove();    $([style]).attr(style);    $(head).append(<link rel="stylesheet" href="http://mrcoles.com/media/test/markdown-css/markdown.css" type="text/css" />);    $(body).addClass(markdown).css({width600pxmargin2em autoword-wrapbreak-word});    $(a img).css({max-height1emmax-width1em});  

 

Markdown.css样式简介