字体
字体选择很重要
使用易于阅读的字体很重要。字体为您的文本增加了价值。为字体选择正确的颜色和文本大小也很重要。
通用字体族
在 CSS 中,有五个通用字体族:
- 衬线字体(Serif):在每个字母的边缘都有一个小的笔触。它们营造出一种形式感和优雅感
- 无衬线字体(Sans-serif):字体线条简洁(没有小笔画)。它们营造出现代而简约的外观
- 等宽字体(Monospace):这里所有字母都有相同的固定宽度。它们创造出机械式的外观
- 草书字体(Cursive):模仿了人类的笔迹
- 幻想字体(Fantasy):是装饰性俏皮的字体
所有不同的字体名称都属于这五个通用字体系列之一。
注
在计算机屏幕上,无衬线字体被认为比衬线字体 更易于阅读
一些字体的例子
通用字体族 | 字体名称实例 |
---|---|
衬线字体(Serif) | Times New Roman Georgia Garamond |
无衬线字体(Sans-serif) | Arial Verdana Helvetica |
等宽字体(Monospace) | Courier New Lucida Console Monaco |
草书字体(Cursive) | Brush Script MT Lucida Handwriting |
幻想字体(Fantasy) | Copperplate Papyrus |
font-family 属性
在 CSS 中,使用 font-family
属性规定文本的字体。
font-family
属性应包含多个字体名称作为 “后备” 系统,以确保浏览器和操作系统之间的最大兼容性。请以您需要的字体开始,并以通用系列结束(如果没有其他可用字体,则让浏览器选择通用系列中的相似字体)。字体名称应以逗号分隔。
提示
如果字体名称不止一个单词,则必须用引号引起来。例如:"Times New Roman"
例如:
<p>这是一个段落,以 Times New Roman 字体显示:</p>
<p class="p1">This is a paragraph, shown in the Times New Roman font.</p>
<p>这是一个段落,以 Arial 字体显示:</p>
<p class="p2">This is a paragraph, shown in the Arial font.</p>
<p>这是一个段落,以 Lucida Console 字体显示:</p>
<p class="p3">This is a paragraph, shown in the Lucida Console font.</p>
.p1 {
font-family: "Times New Roman", Times, serif;
}
.p2 {
font-family: Arial, Helvetica, sans-serif;
}
.p3 {
font-family: "Lucida Console", "Courier New", monospace;
}
字体样式
font-style
属性主要用于指定斜体文本。
此属性可设置三个值:
- normal:文字正常显示
- italic:文本以斜体显示
- oblique:文本为 “倾斜”(倾斜与斜体非常相似,但支持较少)
例如:
<p class="normal">这是一个普通文体的段落。</p>
<p class="italic">这是一个斜体的段落。</p>
<p class="oblique">这是一个倾斜的段落。</p>
p.normal {
font-style: normal;
}
p.italic {
font-style: italic;
}
p.oblique {
font-style: oblique;
}
字体粗细
font-weight
属性指定字体的粗细。例如:
<p class="normal">这是一个段落。</p>
<p class="light">这是一个段落。</p>
<p class="thick">这是一个段落。</p>
<p class="thicker">这是一个段落。</p>
p.normal {
font-weight: normal;
}
p.light {
font-weight: lighter;
}
p.thick {
font-weight: bold;
}
p.thicker {
font-weight: 900;
}
- normal:定义标准的字符。默认值
- lighter:定义更细的字符
- bold:定义粗的字符
- 100-900:定义由粗到细的字符。
400
等同于normal
,而700
等同于bold
字体变体
font-variant
属性指定是否以 small-caps
字体(小型大写字母)显示文本。
在 small-caps
字体中,所有小写字母都将转换为大写字母。但是,转换后的大写字母的字体大小 小于 文本中原始大写字母的字体大小。例如:
<p class="normal">My name is Bill Gates.</p>
<p class="small">My name is Bill Gates.</p>
p.normal {
font-variant: normal;
}
p.small {
font-variant: small-caps;
}
字体大小
font-size
属性设置文本的大小。
在网页设计中,能够管理文本大小很重要。但是,不应使用调整字体大小来使段落看起来像标题,或是使标题看起来像段落。
请始终使用正确的 HTML 标签。例如:<h1>
- <h6>
用于标题,而 <p>
仅用于段落。
font-size
值可以是绝对或相对尺寸大小。
绝对尺寸:
- 将文本设置为指定大小
- 不允许用户在所有浏览器中更改文本大小(可访问性不佳)
- 当输出的物理尺寸已知时,绝对尺寸很有用
相对尺寸:
- 设置相对于周围元素的大小
- 允许用户在浏览器中更改文本大小
注
如果您没有指定字体大小,则普通文本(如段落)的默认大小为 16px
(16px = 1em
)
以像素设置字体大小
使用像素设置文本大小可以完全控制文本大小。例如:
<h1>这是标题 1</h1>
<h2>这是标题 2</h2>
<p>这是一个段落。</p>
<p>这是另一个段落。</p>
h1 {
font-size: 40px;
}
h2 {
font-size: 30px;
}
p {
font-size: 14px;
}
用 em 设置字体大小
为了允许用户调整文本大小(在浏览器菜单中),许多开发人员使用 em
而不是像素。
W3C 建议使用 em
尺寸单位。
1em
等于当前字体大小。浏览器中的默认文本大小为 16px
。因此,默认大小 1em
为 16px
。
可以使用这个公式从像素到 em
来计算大小:pixels/16=em
。例如:
<h1>这是标题 1</h1>
<h2>这是标题 2</h2>
<p>这是一个段落。</p>
<p>这是另一个段落。</p>
h1 {
font-size: 2.5em; /* 40px/16=2.5em */
}
h2 {
font-size: 1.875em; /* 30px/16=1.875em */
}
p {
font-size: 0.875em; /* 14px/16=0.875em */
}
使用百分比和 Em 的组合
例如:
<h1>这是标题 1</h1>
<h2>这是标题 2</h2>
<p>这是一个段落。</p>
<p>这是另一个段落。</p>
body {
font-size: 100%;
}
h1 {
font-size: 2.5em;
}
h2 {
font-size: 1.875em;
}
p {
font-size: 0.875em;
}
响应式字体大小
可以使用 vw
单位设置文本大小,它的意思是 “视口宽度”("viewport width")。
视口(Viewport)是浏览器窗口的大小。1vw
= 视口宽度的 1%
。如果视口为 50
厘米宽,则 1vw
为 0.5
厘米。
这样,文本大小将遵循浏览器窗口的大小,请调整浏览器窗口的大小,以查看字体大小如何缩放。例如:
<head>
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
</head>
<body>
<h1 style="font-size: 10vw;">响应式文本</h1>
<p style="font-size: 5vw;">请调整浏览器窗口的大小,以查看文本大小如何缩放。</p>
<p style="font-size: 5vw;">调整文本大小时,请使用 "vw" 单位。 10vw 将尺寸设置为视口宽度的 10%。</p>
<p>视口是浏览器窗口的大小。 1vw = 视口宽度的 1%。如果视口为 50 厘米宽,则 1vw 为 0.5 厘米。</p>
</body>
谷歌字体
如果您不想使用 HTML 中的任何标准字体,则可以使用 Google Fonts API 向页面添加数百种其他字体。
只需添加一个样式表链接并引用您选择的字体系列。例如:
<head>
<link rel="stylesheet" href="https://fonts.googleapis.com/css?family=Sofia" />
</head>
<body>
<h1>Sofia Font</h1>
<p>Lorem ipsum dolor sit amet, consectetuer adipiscing elit.</p>
</body>
body {
font-family: "Sofia";
font-size: 22px;
}
简写字体属性
为了缩短代码,也可以在一个属性中指定所有单个字体属性。
font
属性是以下属性的简写属性:
- font-style:定义字体的风格
- font-variant:定义小型大写字母文本
- font-weight:定义文本的粗细
- font-size/line-height:定义字体的尺寸,设置行间的距离(行高)
- font-family:定义文本的字体
例如:
<p class="a">这是一个段落。字体大小设置为 20 像素,字体系列为 Arial。</p>
<p class="b">这是一个段落。字体设置为斜体和粗体,字体大小设置为 12 像素,行高设置为 30 像素,字体家族为 Georgia。</p>
p.a {
font: 20px Arial, sans-serif;
}
p.b {
font: italic bold 12px/30px Georgia, serif;
}
注意
font-size
和 font-family
的值是必需的。如果缺少其他值之一,则会使用其默认值