原文:http://www.zcfy.cc/article/383

你可能正在使用 `

  1. function cool(x) {
  2. return x + 1;
  3. }
  1. 解释一下:在`
  2. <pre><code>`和代码之间有一个换行,而这也会被显示成一个空行,这非常讨厌。没有非常好的 CSS 方法来解决这个问题,最好的方法是与 `
  3. <pre>` 标签同一行开始代码,或者用编译程序来去除这里的换行。
  4. ![](https://p5.ssl.qhimg.com/d/inn/26e7fa78/code1.jpg)
  5. ### 选择一个字体
  6. 由于 `
  7. <pre>` 标签主要是用来显示代码块,而代码通常使用等宽字体,因此将 `
  8. <pre>` 的样式字体设置成等宽字体是个好主意。
  9. 对我们来说幸运地是,浏览器默认字体已经将 `
  10. <pre>` 设置成等宽字体,因此你可以不做任何处理。当然,你可以设置一个你喜欢的字体。
  11. 这里有篇[文章](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 较好地利用了跨平台系统预装字体。
  12. ```null
  13. font-family: Consolas, "Andale Mono WT", "Andale Mono", "Lucida Console",
  14. "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono",
  15. "Liberation Mono", "Nimbus Mono L", Monaco, "Courier New", Courier, monospace

【译】使用 <pre> 标签样式的注意事项 - 奇舞团博客 - 图1
我不确定 font stack 在今天有没有过时,不管怎样这是一个好的开端。
另外,你可以用自定义字体。或者使用第三方服务。在我写下这篇文章的时候,Typekit 提供了 23 种等宽字体

折行还是不折行?

这有关个人偏好,对我个人来说,分两种情况。
当我自己在编辑器写代码时,我倾向于让代码自动折行而不出现水平滚动条。而当我在文章中阅读代码时,我喜欢代码不折行。我知道这很奇怪。在 CodePen 里,我们将折不折行提供成一个选项让用户自己选择,因为大家本来就是萝卜青菜各有所爱。
【译】使用 <pre> 标签样式的注意事项 - 奇舞团博客 - 图2
在展示代码的时候,你需要选择究竟是否折行。如果你选择折行,幸运地,你可以使用为`

  1. 这是我所能做的保证代码块中很长的一行不会破坏掉布局。(一般我们除了加上面的那个外,还加上 `word-wrap: break-word` `word-break: break-all` —— 译者注)
  2. ### 你需要代码语法高亮吗?
  3. 网上不乏各种语法高亮方案,你可以搜索自己喜欢的方案。我个人推崇 [Prism.js](http://prismjs.com/),因为:
  4. 1. 它代码量少。
  5. 2. 它无依赖。
  6. 3. 它对标签的 class 起名起的好。
  7. 4. 它允许你 copy 它的代码自己修改和定制。
  8. ![](https://p5.ssl.qhimg.com/d/inn/ff88cf21/screen.jpg)
  9. 除非从 server 端直接生成 `<span>` 的样式(用来语法分色),不然 Prism.js 已经足够好了。
  10. ### 你标注了代码是什么语言了吗?
  11. 我个人比较喜欢在代码块上标准出使用的语言。
  12. 比如:
  13. ![](https://p5.ssl.qhimg.com/d/inn/02d3a06b/screen2.png)
  14. 标记出语言的其中一种方式是通过 `data-*` 属性(可能你的语法高亮工具也已经要求你标记出)然后显示它,例如:
  15. ```null
  16. <pre data-lang="HTML"><code>
  17. <h1>Example code</h1>
  18. <code></pre>
  1. pre[data-lang]::before {
  2. content: attr(data-lang);
  3. display: block;
  4. }

我想这也不是一种特别简单的方法,所以可能一些人只是简单在代码里注释一下。也许用 title 属性是更好的选择?

控制空格

如果你使用 tab 来缩进,你可能会觉得缩进太宽了。
默认情况下,tab 被按照 8 个空格来渲染,这很荒唐。
【译】使用 <pre> 标签样式的注意事项 - 奇舞团博客 - 图3
在写代码的时候,我们通常让 tab 宽度为 4 个空格。幸运地,你可以用样式控制它:

  1. pre {
  2. tab-width: 4;
  3. }

就我个人而言,我喜欢直接用空格缩进。

其他选择

努力让代码块很好地展示在网页上可不是一件琐事,它是值得做的工作。如果你不想自己做这些工作,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

  1. ` 标签的语义表示其中的文本是代码。这对我来说尤其有用,当我需要显示一段代码时,使用它们,下面是一个例子:
  2. ```null
  1. ` 标签吗?
  2. `