你可能正在使用 `
function cool(x) {
return x + 1;
}
解释一下:在`
<pre><code>`和代码之间有一个换行,而这也会被显示成一个空行,这非常讨厌。没有非常好的 CSS 方法来解决这个问题,最好的方法是与 `
<pre>` 标签同一行开始代码,或者用编译程序来去除这里的换行。
![](https://p5.ssl.qhimg.com/d/inn/26e7fa78/code1.jpg)
### 选择一个字体
由于 `
<pre>` 标签主要是用来显示代码块,而代码通常使用等宽字体,因此将 `
<pre>` 的样式字体设置成等宽字体是个好主意。
对我们来说幸运地是,浏览器默认字体已经将 `
<pre>` 设置成等宽字体,因此你可以不做任何处理。当然,你可以设置一个你喜欢的字体。
这里有篇[文章](https://www.sitepoint.com/eight-definitive-font-stacks/)是 Michael Tuck 写于 2009 年的,他研究了[“font stacks”](https://css-tricks.com/snippets/css/font-stacks/)。font stack 是说将一组字体罗列在一个 `font-family` 标签中,首选字体列在前面,备选字体依次列在其后。他的等宽字体 font stack 较好地利用了跨平台系统预装字体。
```null
font-family: Consolas, "Andale Mono WT", "Andale Mono", "Lucida Console",
"Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono",
"Liberation Mono", "Nimbus Mono L", Monaco, "Courier New", Courier, monospace
我不确定 font stack 在今天有没有过时,不管怎样这是一个好的开端。
另外,你可以用自定义字体。或者使用第三方服务。在我写下这篇文章的时候,Typekit 提供了 23 种等宽字体。
折行还是不折行?
这有关个人偏好,对我个人来说,分两种情况。
当我自己在编辑器写代码时,我倾向于让代码自动折行而不出现水平滚动条。而当我在文章中阅读代码时,我喜欢代码不折行。我知道这很奇怪。在 CodePen 里,我们将折不折行提供成一个选项让用户自己选择,因为大家本来就是萝卜青菜各有所爱。
在展示代码的时候,你需要选择究竟是否折行。如果你选择折行,幸运地,你可以使用为`
这是我所能做的保证代码块中很长的一行不会破坏掉布局。(一般我们除了加上面的那个外,还加上 `word-wrap: break-word` 和 `word-break: break-all` —— 译者注)
### 你需要代码语法高亮吗?
网上不乏各种语法高亮方案,你可以搜索自己喜欢的方案。我个人推崇 [Prism.js](http://prismjs.com/),因为:
1. 它代码量少。
2. 它无依赖。
3. 它对标签的 class 起名起的好。
4. 它允许你 copy 它的代码自己修改和定制。
![](https://p5.ssl.qhimg.com/d/inn/ff88cf21/screen.jpg)
除非从 server 端直接生成 `<span>` 的样式(用来语法分色),不然 Prism.js 已经足够好了。
### 你标注了代码是什么语言了吗?
我个人比较喜欢在代码块上标准出使用的语言。
比如:
![](https://p5.ssl.qhimg.com/d/inn/02d3a06b/screen2.png)
标记出语言的其中一种方式是通过 `data-*` 属性(可能你的语法高亮工具也已经要求你标记出)然后显示它,例如:
```null
<pre data-lang="HTML"><code>
<h1>Example code</h1>
<code></pre>
pre[data-lang]::before {
content: attr(data-lang);
display: block;
}
我想这也不是一种特别简单的方法,所以可能一些人只是简单在代码里注释一下。也许用 title
属性是更好的选择?
控制空格
如果你使用 tab 来缩进,你可能会觉得缩进太宽了。
默认情况下,tab 被按照 8 个空格来渲染,这很荒唐。
在写代码的时候,我们通常让 tab 宽度为 4 个空格。幸运地,你可以用样式控制它:
pre {
tab-width: 4;
}
其他选择
努力让代码块很好地展示在网页上可不是一件琐事,它是值得做的工作。如果你不想自己做这些工作,CodePen 提供了内嵌版可以很好地演示代码(还可以预览),内嵌 GitHub Gists 也是一个不错的选择。
悲催的国内,两个网站访问都慢 ╮(╯▽╰)╭ —— 译者注
英文原文:http://mediatemple.net/blog/tips/considerations-for-styling-the-pre-tag/
https://75.team/post/considerations-for-styling-the-%3C-pre-%3E-tag.html
` 标签的语义表示其中的文本是代码。这对我来说尤其有用,当我需要显示一段代码时,使用它们,下面是一个例子:
```null
` 标签吗?
`