markdown.css 让 HTML 显示成 Markdown 纯文本 见证 CSS 的强大

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

基于 LESS 编写

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

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

标题

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

h2:before {
  content: "## ";
  display: inline;
}

强调

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

@em-char: "*";
em:before, em:after {
  content: @em-char;
  display: inline;
}

strongcode 的实现类似。

链接

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

a {
  text-decoration: none;
}
a:before {
  content: "[";
  display: inline;
  color: @color;
}

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

a:after {
  content: ~'"](" attr(href) ")"';
  display: inline;
  color: @color;
}

pre

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

@four-space: 34px;
@four-space-css3: ~"4ch"; 
pre {
  margin-left: @four-space;
  padding-left: @four-space-css3;
}

引用

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

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

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

blockquote {
  position: relative;
  padding-left: @four-space/2;
  padding-left: @two-space-css3;
  overflow: hidden;

  &:after {
	  // 100 lines max
	  // the \A becomes a newline character and `white-space: pre`
	  // 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>";
	  white-space: pre;
	  position: absolute;
	  top: 0;
	  left: 0;
	  font-size: @font-size;
	  line-height: @line-height;
  }
}

图片

前面已经说过图片会照常显示。使用如下代码可以让图片也显示成 Markdown 形式,其原理和对链接的处理一样,不过只有 Opera 浏览器支持对 img 应用 :before:after 伪类:

img {
  display: inline-block;
  &:before {
	  content: ~'"![" attr(alt)';
	  display: inline-block;
  }
  &:after {
	  content: ~'"](" attr(src) ")"';
	  display: inline-block;
  }
}

markdownify

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


$('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({width: '600px', margin: '2em auto', 'word-wrap': 'break-word'}); $('a img').css({'max-height': '1em', 'max-width': '1em'});

编撰SegmentFault

我来评几句
登录后评论

已发表评论数()

相关站点

热门文章