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;
- }
strong、code的实现类似。
链接
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 `whitewhite-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>";
- whitewhite-space: pre;
- position: absolute;
- top: 0;
- left: 0;
- font-size: @font-size;
- line-height: @line-height;
- }
- }
图片
使用如下 CSS 可以实现图片转为 markdown 形式显示:
- img { content: "" }
- img:before {
- content: "![";
- color: #333333;
- }
- img:after {
- content: "](" attr(src) ")";
- color: #333333;
- }
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'});
相关文章
通过CSS3的object-fit来调整图片适配尺寸的技巧简介
这篇文章主要介绍了通过CSS3的object-fit来调整图片适配尺寸的技巧,包括用object-fit来居中并裁剪图片的方法,需要的朋友可以参考下2016-02-27- 这篇文章主要介绍了CSS计数器counter()的用法,是CSS入门学习中的基础知识,需要的朋友可以参考下2015-09-26
- 这篇文章主要介绍了CSS中的伪元素,是CSS入门学习中的基础知识,需要的朋友可以参考下2015-08-01
- 这篇文章主要介绍了CSS中的各种选择符,是CSS入门学习中的基础知识,需要的朋友可以参考下2015-07-17
- CSS里一直有一个让我们头疼的问题,就是创建布局很麻烦。当然,有很多方式,有很多技术都可以创建各种布局,但我们总觉得CSS里应该提供一些新属性,让我们能更好的管理布局2014-05-03
定义css设备类型-Media Queries图表简介及使用方法
CSS3完美地解决了让同一个网站同时适应完全不同尺寸的屏幕这些问题;css3提出的MediaQueries解决了为网站设计不同的CSS样式文件,如打印样式表文件,手机样式文件,电脑样式2013-01-21css3背景图片透明叠加属性cross-fade简介及用法实例
据说iOS6系统(iPhone5)增加了两个CSS3属性,一个是CSS3 filters – CSS3滤镜另外一个是CSS3 Cross-fade – CSS3交叉淡入淡出,接下来为您介绍cross-fade属性,感兴趣的朋友2013-01-08- 本文主要介绍了通用的css hack2012-07-11
- CSS Sprites 技术对于广大的前端工程师来说应该是一点也不陌生。这个被国内开发者昵称为CSS精灵 CSS雪碧的家伙到底解决了什么问题,我们又怎样合理使用这个技术呢?下面让我2012-05-31
- 国外人士非常重视网站的易用性,相当一部分外国站点已经使用em作为字体单位.2009-12-27
最新评论