Markdown.css样式简介

时间:2021-05-08

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

基于 LESS 编写

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

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

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

CSS Code复制内容到剪贴板
  • h2:before{
  • content:"##";
  • display:inline;
  • }
  • 强调

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

    CSS Code复制内容到剪贴板
  • @em-char:"*";
  • em:before,em:after{
  • content:@em-char;
  • display:inline;
  • }
  • strong、code的实现类似。
    链接

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

    CSS Code复制内容到剪贴板
  • a{
  • text-decoration:none;
  • }
  • a:before{
  • content:"[";
  • display:inline;
  • color:@color;
  • }
  • 后面添加的内容中包含链接,可以通过 attr(href) 取得:

    CSS Code复制内容到剪贴板
  • a:after{
  • content:~'"]("attr(href)")"';
  • display:inline;
  • 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{
  • position:relative;
  • padding-left:@four-space/2;
  • padding-left:@two-space-css3;
  • overflow:hidden;
  • &:after{
  • //100linesmax
  • //the\Abecomesanewlinecharacterand`whitewhite-space:pre`
  • //makesitactlikea<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-space:pre;
  • position:absolute;
  • 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('<linkrel="stylesheet"href="http://mrcoles.com/media/test/markdown-css/markdown.css"type="text/css"/>');
  • $('body').addClass('markdown').css({width:'600px',margin:'2emauto','word-wrap':'break-word'});
  • $('aimg').css({'max-height':'1em','max-width':'1em'});
  • 声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

    相关文章