Markdown.css样式简介

你瞧,你绿油油的小草从土里钻了出来。嫩嫩的,它在饱受严冬的考验之后,在严冬它聚集着力量,想在春天到来时,将力量释放出来,它展示出了生命力的顽强,也展现出自己对春天的渴望!在万物最需要水的时候,春雨悄悄地轻轻地到来了。生怕踩到了这些顽强的小精西。春雨打在小草的脸上,轻轻地。小草贪婪的吮吸着春雨,一会儿,春风也来 "凑热闹 "了,春风来为柳树 "梳头 "来了,春风也轻轻地,怕自己的鲁莽把柳树的头发弄断了。

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

基于 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. &:after{
  7. //100linesmax
  8. //the\Abecomesanewlinecharacterand`whitewhite-space:pre`
  9. //makesitactlikea<br>
  10. 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>";
  11. whitewhite-space:pre;
  12. position:absolute;
  13. top:0;
  14. left:0;
  15. font-size:@font-size;
  16. line-height:@line-height;
  17. }
  18. }

图片

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

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

markdownify

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


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

本文Markdown.css样式简介到此结束。如果朋友让你生气,那就说明你仍然在意他的友情。小编再次感谢大家对我们的支持!

您可能有感兴趣的文章
css让页脚保持在底部位置的四种方案

Flex布局史上最简单使用语法教程

新的CSS 伪类函数 :is() 和 :where()示例详解

纯CSS打字动画的如何实现示例

CSS浮动引起的高度塌陷问题