markdown html图片,Markdown.css样式简介

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

5063858d52d62230f7a0704eeb0e1116.png

基于 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 {

// 100 lines max

// the \A becomes a newline character and `whitewhite-space:pre`

// makes it act like a 

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('');

$('body').addClass('markdown').css({width:'600px',margin:'2em auto','word-wrap':'break-word'});

$('a img').css({'max-height':'1em','max-width':'1em'});

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值