为列表添加样式

列表大体上和其他文本一样,但是仍有一些你需要知道的特殊 CSS 属性,和一些可供参考的最佳实践,这篇文章将阐述这一切。

前提: 基本的计算机知识,HTML 基础(已学习 HTML 介绍),CSS 基础(已学习 CSS 基础),掌握基本的 CSS 文本和字体样式
目标: 熟悉与列表相关的样式和最佳实践

一个简单的列表示例

首先,让我们看一个简单的列表示例。文章中我们将看到无序、有序和描述列表——它们都具有相似的样式特性,而某些特性却又各不相同。Github 上有无额外样式的例子(也可以查看源码)。

示例列表的 HTML 代码如下:

html
<h2>Shopping (unordered) list</h2>

<p>
  Paragraph for reference, paragraph for reference, paragraph for reference,
  paragraph for reference, paragraph for reference, paragraph for reference.
</p>

<ul>
  <li>Hummus</li>
  <li>Pita</li>
  <li>Green salad</li>
  <li>Halloumi</li>
</ul>

<h2>Recipe (ordered) list</h2>

<p>
  Paragraph for reference, paragraph for reference, paragraph for reference,
  paragraph for reference, paragraph for reference, paragraph for reference.
</p>

<ol>
  <li>Toast pita, leave to cool, then slice down the edge.</li>
  <li>
    Fry the halloumi in a shallow, non-stick pan, until browned on both sides.
  </li>
  <li>Wash and chop the salad.</li>
  <li>Fill pita with salad, hummus, and fried halloumi.</li>
</ol>

<h2>Ingredient description list</h2>

<p>
  Paragraph for reference, paragraph for reference, paragraph for reference,
  paragraph for reference, paragraph for reference, paragraph for reference.
</p>

<dl>
  <dt>Hummus</dt>
  <dd>
    A thick dip/sauce generally made from chick peas blended with tahini, lemon
    juice, salt, garlic, and other ingredients.
  </dd>
  <dt>Pita</dt>
  <dd>A soft, slightly leavened flatbread.</dd>
  <dt>Halloumi</dt>
  <dd>
    A semi-hard, unripened, brined cheese with a higher-than-usual melting
    point, usually made from goat/sheep milk.
  </dd>
  <dt>Green salad</dt>
  <dd>That green healthy stuff that many of us just use to garnish kebabs.</dd>
</dl>

现在,如果你去到示例的展示页面,并使用浏览器开发者工具查看那些列表元素,你会注意到若干个默认的样式预设值:

  • <ul><ol> 元素含有 16px1em)的顶部和底部 margin40px2.5em)的 padding-left
  • 列表项(<li> 元素)默认是没有设置间距的。
  • <dl> 元素设置含有 16px1em)的顶部和底部 margin,但不含内边距。
  • <dd> 元素含有 40px2.5em)的 margin-left
  • 在参考中提到的 <p> 元素设置含有 16px1em)的顶部和底部 margin——与其他的列表类型相同。

处理列表间距

当为列表添加样式时,你需要调整样式,使其保持与周围元素相同的垂直间距(例如段落和图片,有时称为垂直节奏)和相互间的水平间距(你可以在 Github 上参考完成添加样式后的示例 ,也可以找到源代码)。

用于文本样式和间距的 CSS 如下所示:

css
/* 通用样式 */

html {
  font-family: Helvetica, Arial, sans-serif;
  font-size: 10px;
}

h2 {
  font-size: 2rem;
}

ul,
ol,
dl,
p {
  font-size: 1.5rem;
}

li,
p {
  line-height: 1.5;
}

/* 描述列表样式 */

dd,
dt {
  line-height: 1.5;
}

dt {
  font-weight: bold;
}
  • 第一条规则集设置一个网站字体,基准字体大小为 10px。页面上的所有内容都将继承该规则集。
  • 规则集 2 和 3 为标题、不同的列表类型和段落以及设置了相对字体大小(这些列表的子元素将会继承该规则集),这就意味着每个段落和列表都将拥有相同的字体大小和上下间距,有助于保持垂直间距一致。
  • 规则集 4 在段落和列表项目上设置相同的 line-height,因此段落和每个单独的列表项目将在行之间具有相同的间距。这也将有助于保持垂直间距一致。
  • 规则集 5 和 6 适用于描述列表。我们在描述列表的术语和其描述上设置与段落和列表项相同的 line-height。再次强调一遍,这里很好地实现了一致性!我们还使描述术语具有粗体字体,因此它们在视觉上脱颖而出。

列表特定样式

现在我们来看一下列表的一般间距,我们来研究一些列表具有的特定属性。我们从三个属性开始了解,这三个属性可以在 <ul><ol> 元素上设置:

  • list-style-type:设置用于列表的项目符号的类型,例如无序列表的方形或圆形项目符号,或有序列表的数字、字母或罗马数字。
  • list-style-position:设置在每个项目开始之前,项目符号是出现在列表项内,还是出现在其外。
  • list-style-image:允许为项目符号使用自定义图片,而不是简单的方形或圆形。

符号样式

像上面所提及的,list-style-type 属性允许你设置项目符号的类型,在我们的示例中,我们在有序列表上设置了大写罗马数字:

css
ol {
  list-style-type: upper-roman;
}

效果显示如下:

一个有序列表,项目符号被设置为出现在列表项之外

你可以通过 list-style-type 参考页面查找到更多选项。

项目符号位置

list-style-position 设置在每个项目开始之前,项目符号是出现在列表项内,还是出现在其外。如上所示,默认值为 outside,这使项目符号位于列表项之外。

如果值设置为 inside,项目符号则位于行内。

css
ol {
  list-style-type: upper-roman;
  list-style-position: inside;
}

一个有序列表,项目符号被设置为出现在列表项之内

使用自定义的项目符号图片

list-style-image 属性允许对于项目符号使用自定义图片。其语法相当简单:

css
ul {
  list-style-image: url(star.svg);
}

然而,这个属性在控制项目符号的位置,大小等方面是有限的。最好使用 background 系列属性,你将在背景和边框文章中了解更多信息。在这里我们仅做一点尝试!

在我们的示例中,我们的无序列表最终样式像这样(在之前所见的顶部):

css
ul {
  padding-left: 2rem;
  list-style-type: none;
}

ul li {
  padding-left: 2rem;
  background-image: url(star.svg);
  background-position: 0 0;
  background-size: 1.6rem 1.6rem;
  background-repeat: no-repeat;
}

我们做了这些事情:

  • <ul>padding-left 从默认的 40px 下调为 20px,然后在列表项上设置相同的数值。这就是说,整个列表项仍然排列在列表中,但是列表项产生了一些用于背景图像的填充。如果我们没有设置填充,背景图像将与列表项文本重叠,这看起来会很乱。

  • list-style-type 设置为 none,以便默认情况下不会显示项目符号。我们将使用 background 属性来代替项目符号。

  • 为每个无序列表项插入项目符号,相关的属性如下:

    • background-image:充当项目符号的图片文件的参照路径。
    • background-position:这定义了所选元素背景中的图像将出现在哪里——在我们的示例中设置为 0 0,这意味着项目符号将出现在每个列表项的最左上侧。
    • background-size:设置背景图片的大小。理想条件下,我们想要项目符号与列表项的大小相同(比列表项稍大或稍小亦可)。我们使用的尺寸为 1.6rem16px),它非常吻合我们为项目符号设置的 20px 的填充,16px 加上 4px 的空格间距,可以使项目符号和列表项文本效果更好。
    • background-repeat:默认条件下,背景图片不断复制直到填满整个背景空间,在我们的示例中,背景图片只需复制一次,所以我们设置值为 no-repeat

效果显示如下:

一个无序列表,其项目符号设置为了小星星的图片

list-style 简写

上述提到的三种属性可以用一个单独的简写属性 list-style 来设置。例如,以下 CSS:

css
ul {
  list-style-type: square;
  list-style-image: url(example.png);
  list-style-position: inside;
}

可以被如下方式代替:

ul {
  list-style: square url(example.png) inside;
}

属性值可以任意顺序排列,你可以设置一个,两个或者所有三个值(不包括的属性使用的默认值是 discnoneoutside),如果指定了 typeimage,如果由于某种原因导致图像无法加载,则 type 将用作回退。

管理列表计数

有时,你可能想在有序列表上进行不同的计数方式。例如:从 1 以外的数字开始,或从后面倒数,或者按大于 1 的步长计数。HTML 和 CSS 有一些工具可以帮助你:

start

start 属性允许你从 1 以外的数字开始计数。以下示例:

html
<ol start="4">
  <li>Toast pita, leave to cool, then slice down the edge.</li>
  <li>
    Fry the halloumi in a shallow, non-stick pan, until browned on both sides.
  </li>
  <li>Wash and chop the salad.</li>
  <li>Fill pita with salad, hummus, and fried halloumi.</li>
</ol>

输出的结果如下:

reversed

reversed 属性将使列表反向计数。以下示例:

html
<ol start="4" reversed>
  <li>Toast pita, leave to cool, then slice down the edge.</li>
  <li>
    Fry the halloumi in a shallow, non-stick pan, until browned on both sides.
  </li>
  <li>Wash and chop the salad.</li>
  <li>Fill pita with salad, hummus, and fried halloumi.</li>
</ol>

输出的结果如下:

备注: 如果反向计数的列表项数比 start 属性的值还要多,计数将继续到零并向负数方向增加。

value

value 属性允许设置列表项指定数值,以下示例:

html
<ol>
  <li value="2">Toast pita, leave to cool, then slice down the edge.</li>
  <li value="4">
    Fry the halloumi in a shallow, non-stick pan, until browned on both sides.
  </li>
  <li value="6">Wash and chop the salad.</li>
  <li value="8">Fill pita with salad, hummus, and fried halloumi.</li>
</ol>

输出的结果如下:

备注: 即使使用非数字的 list-style-type,仍需要在 value 属性中使用等效的数值。

动手练习:为嵌套式列表添加样式

在该学习环节,我们希望你使用如上所学尝试为一个嵌套式列表添加样式。我们已经提供了 HTML 代码,在此之上请完成如下任务:

  1. 为该无序列表提供方形项目符号。
  2. 为该无序列表项和有序列表项提供基于其字体大小 1.5 倍的行高。
  3. 为有序列表提供小写字母的项目符号。
  4. 对列表进行自由发挥,尝试不同的项目符号类型,间距,以及其他的各种属性。

如果犯了错误,可以随时点击重置按钮进行重新设置。如果你真的遇到困难无法继续下去,点击显示解答按钮查看一种可能的解法。

总结

一旦你掌握一些相关的基础原则和特定属性,列表的样式还是相对容易理解的。在下篇文章中我们将转到另一话题——为链接提供样式的各种技巧。

参见

CSS 计数器提供用于自定义列表计数和样式的高级工具,但它们相当复杂。如果你想更深入了解,请查看如下资源: