`

你该知道的字体 font-family

    博客分类:
  • CSS
阅读更多

字体的分类

就 Web 常用的一些字体而言,经常听说的字体类型,大致可以分为这几种:

  • serif(衬线)
  • sans-serif(无衬线)
  • monospace(等宽)
  • fantasy(梦幻)
  • cuisive(草体)

其实大体上分为衬线字体和无衬线字体,等宽字体中也有衬线等宽和无衬线等宽字体,这 5 个分类是 font-family 的 5 个可用字体系列取值。

也就是说,上述 5 个名字,代表的并非某个特定字体,而是一系列字体,这些通用的名称允许用户代理(通常就是浏览器)从相应集合中选择一款字体。

这也很好解释了,font-family 中的 family ,家庭的意思,也就是不单单指一个,而是可以指定多个,上述 5 个英文单词都是 font-family 的可用取值,下文还会详细讲到。

 

serif -- 衬线字体

serif,意为有衬线的字体,衬线的意思是在字符笔画末端有叫做衬线的小细节的额外装饰,而且笔画的粗细会有所不同,这些细节在大写字母中特别明显。

OK,那么有哪些常用字体属于衬线字体呢?

宋体(SimSun)

Windows 下大部分浏览器的默认中文字体,是为适应印刷术而出现的一种汉字字体。笔画有粗细变化,是一种衬线字体,宋体在小字号下的显示效果还可以接受,但是字号一大体验就很差了,所以使用的时候要注意,不建议做标题字体使用。

Times New Roman

Mac 平台 Safari 下默认的英文字体,是最常见且广为人知的西文衬线字体之一,众多网页浏览器和文字处理软件都是用它作为默认字体。

 

sans-serif -- 无衬线字体

sans 的意思是无,sans-serif 也就是无衬线的意思。专指西文中没有衬线的字体,与汉字字体中的黑体相对应。与衬线字体相反,该类字体通常是机械的和统一线条的,它们往往拥有相同的曲率,笔直的线条,锐利的转角。

中文下,无衬线字体就是黑体,黑体字也就是又称方体或等线体,没有衬线装饰,字形端庄,笔画横平竖直,笔迹全部一样粗细。

看看又有哪些常见的无衬线字体。

微软雅黑(Microsoft Yahei)

大名鼎鼎的微软雅黑相信都不陌生,从 windows Vista 开始,微软提供了这款新的字体,一款无衬线的黑体类字体,显著提高了字体的显示效果。现在这款字体已经成为 windows 浏览器最值得使用的中文字体。

华文黑体(STHeiti)、华文细黑(STXihei)

属于同一字体家族系列,MAC OS X 10.6 之前的简体中文系统界面的默认中文字体,正常粗细就是华文细黑,粗体下则是华文黑体。

黑体-简(Heiti SC)

从 MAC OS X 10.6 开始,黑体-简代替华文黑体用作简体中文系统界面默认字体,苹果生态最常用的字体之一,包括 iPhone、iPad 等设备用的也是这款字体。

冬青黑体(Hiragino Sans GB)

又叫苹果丽黑,Hiragino 是字游工房设计的系列字体名称。是一款清新的专业印刷字体,小字号时足够清晰,Mac OS X 10.6 开始自带有 W3 和 W6 。

Helvetica、Helvetica Neue

被广泛用于全世界使用拉丁字母和西里尔字母的国家。Helvetica 是苹果电脑的默认字体,微软常用的Arial 字体也来自于它。

Arial

Windows 平台上默认的无衬线西文字体,有多种变体,比例及字重(weight)和 Helvetica 极为相近。

Verdana

无衬线字体,优点在于它在小字上仍结构清晰端整、阅读辨识容易。

Tahoma

十分常见的无衬线字体,字体结构和 Verdana 很相似,其字元间距较小,而且对 Unicode 字集的支持范围较大。许多不喜欢 Arial 字体的人常常会改用 Tahoma 来代替,除了是因为 Tahoma 很容易取得之外,也是因为 Tahoma 没有一些 Arial 为人诟病的缺点,例如大写“i”与小写“L”难以分辨等。(这里故意反过来写)。

 

monospace -- 等宽字体

这系列字体程序员们其实都不陌生。我们用来敲代码的编辑器,字体的选择经常就是一类等宽字体。

等宽字体是指字符宽度相同的电脑字体,常见于 IDE 或者编辑器中,每个字母的宽度相等,通常用于计算机相关书籍中排版代码块。

font-monospace

除了 IDE ,我们看到的技术文章中的代码块中,经常也是使用等宽字体进行排版。

Consolas

这是一套等宽的字体,属无衬线字体。这个字体使用了微软的 ClearType 字型平滑技术,主要是设计做为代码的显示字型之用,特别之处是它的“0”字加入了一斜撇,以方便与字母“O”分辨。

ClearType:由微软在其操作系统中提供的屏幕亚像素微调字体平滑工具,让 Windows 字体更加漂亮。在 Windows XP 平台上,这项技术默认是关闭,到了Windows Vista 才默认为开启。

image

上图是 Github 代码区块的字体设置,可以看到,默认字体就是 Consolas ,紧接着的几个都是其它等宽字体,如果用户的系统中都没有预装这些字体,则会匹配最后一个 monospace ,它表示等宽字体系列,会从用户系统中的等宽字体中选取一个展示。

 

fantasy 、cuisive

fantasy和 cuisive 字体在浏览器中不常用,在各个浏览器中有明显的差异。

 

中文字体的兼容写法

一些中文字体,例如font-family: '宋体',由于字符编码的问题,少部分浏览器解释这个代码的时候,中文出现乱码,这个时候设定的字体无法正常显示。

所以通常会转化成对应的英文写法或者是对应的 unicode 编码,font-family:'宋体' -> font-family: '\5b8b\4f53'

\5b8b\4f53 是宋体两个中文字的 unicode 编码表示。类似的写法还有:

  • 黑体:\9ED1\4F53
  • 微软雅黑:\5FAE\8F6F\96C5\9ED1
  • 华文细黑:\534E\6587\7EC6\9ED1
  • 华文黑体:\534E\6587\9ED1\4F53

Unicode编码: 人们希望在一套系统里面能够容纳所有字符,Unicode 编码解决传统的字符编码方案的局限性,每个字符占用 2 字节。这样理论上一共最多可以表示2^16(即65536)个字符。基本满足各种语言的使用。

 关于Unicode编码,我在下一篇文章里再做介绍

 还有一点:注意URL编码来源及详解HTML字符集的区别

 

字体定义的细节

其他一些小细节也很重要,譬如定义字体的时候,何时需要在字体两端添加引号?像这样:

 

p{
    font-family: 'Microsoft YaHei', '黑体-简', '\5b8b\4f53';
}

 

当字体名字中间有空格,中文名字体及 Unicode 字符编码表示的中文字体,为了保证兼容性,都建议在字体两端添加单引号或者双引号。

 

字体定义顺序

字体定义顺序是一门学问,通常而言,我们定义字体的时候,会定义多个字体或字体系列。举个栗子:

 

body {
    font-family: tahoma, arial, 'Hiragino Sans GB', '\5b8b\4f53', sans-serif;
}

 

别看短短 5 个字体名,其实其中门道很深。解释一下:

  1. 使用 tahoma 作为首选的西文字体,小字号下结构清晰端整、阅读辨识容易;
  2. 用户电脑未预装 tohoma,则选择 arial 作为替代的西文字体,覆盖 windows 和 MAC OS;
  3. Hiragino Sans GB 为冬青黑体,首选的中文字体,保证了 MAC 用户的观看体验;
  4. Windows 下没有预装冬青黑体,则使用 '\5b8b\4f53' 宋体为替代的中文字体方案,小字号下有着不错的效果;
  5. 最后使用无衬线系列字体 sans-serif 结尾,保证旧版本操作系统用户能选中一款电脑预装的无衬线字体,向下兼容。

嗯,其实上面的 font-family 就是淘宝首页 body 的字体定义,非常的规范,每一个字体的定义都有它的意义。

 

 

字体书写规则

综上,总结一下,我觉得字体 font-family 定义的原则大概遵循:

1、兼顾中西

中文或者西文(英文)都要考虑到。

2、西文在前,中文在后

由于大部分中文字体也是带有英文部分的,但是英文部分又不怎么好看,同理英文字体中大多不包含中文。

所以通常会先进行英文字体的声明,选择最优的英文字体,这样不会影响到中文字体的选择,中文字体声明则紧随其次。

3、兼顾多操作系统

选择字体的时候要考虑多操作系统。例如 MAC OS 下的很多中文字体在 Windows 都没有预装,为了保证 MAC 用户的体验,在定义中文字体的时候,先定义 MAC 用户的中文字体,再定义 Windows 用户的中文字体。其次很多人都不知道 Android 下没有预装微软雅黑和宋体,那么 Android 机型下的中文字体设置又是很考究的。

4、兼顾旧操作系统,以字体族系列 serif 和 sans-serif 结尾

当使用一些非常新的字体时,要考虑向下兼容,兼顾到一些极旧的操作系统,使用字体族系列 serif 和sans-serif 结尾总归是不错的选择。

 

 

 

 

 

 

 

 

 

 

.

分享到:
评论

相关推荐

    font-family 你值得拥有的字体样式

    font-family 你值得拥有的字体样式 这个文档可以帮助你如何优雅的选择字体(font-family)

    ubuntu-font-family-0.80

    字体符为ubuntu-font-family,包括Ubuntu-B、Ubuntu-BI、Ubuntu-C、Ubuntu-L、Ubuntu-LI、Ubuntu-M、Ubuntu-MI、UbuntuMono-B、UbuntuMono-BI、UbuntuMono-R等

    font-family中文字体代码示例

    `font-family` 属性在CSS(层叠样式表)中用于定义文本的字体,它允许开发者指定一系列字体,浏览器会按照顺序尝试匹配,直到找到用户计算机上可用的字体。本文将详细解释`font-family`属性在处理中文字体时的应用,...

    CSS font-family为英文和中文字体分别设置不同的字体

    在CSS中,`font-family` 属性用于定义元素的字体系列,它允许我们指定一系列的字体,以便在用户的计算机上找不到首选字体时,浏览器可以尝试使用下一个可用的字体。这是一项重要的样式设置,确保文本在各种设备和...

    css中默认中文字体font-family列表

    当中文字体被指定在font-family属性中时,这个列表就变得尤为重要,因为中文字体的种类繁多,且并不是所有的中文字体都能在所有用户的系统上找到。 对于中文字体而言,常见的CSS默认中文字体包括如下几种,这些字体...

    CSS3 @font-face网页中的字体

    该规则由多个属性组成,包括`font-family`、`src`等,定义了字体家族名称和字体来源。 ```css @font-face { font-family: 'MyWebFont'; src: url('w5-webfont.woff2') format('woff2'), url('w5-webfont.woff') ...

    cssfont-family中英文对照.js

    CSS font-family常见中文字体对应的英文名称,这个是收集的css中的font-family中的中英文对照,可以方便使用。

    农产品网页美化-字体美化-font-size属性.pptx

    本文将详细讲解几个与字体相关的CSS属性,包括`font-size`、`font-family`、`font-weight`、`font-style`以及`word-wrap`,并介绍一种新增的字体使用方法——`@font-face`规则。 首先,`font-size`属性用于设定文本...

    html5自定义字体@font-face

    - `font-family`: 这个属性用于指定字体的名称,可以是任何合法的CSS标识符,但最好使用引号包围以避免混淆。 - `src`: 定义字体文件的URL,可以是相对路径或绝对路径。`format()`函数告诉浏览器字体文件的格式,...

    CSS3@font-face

    制作页面的时候,我们常用“font-family ”来定义字体,然而我们用“font-family “定义的字体在用户的浏览器中是否可以呈现取决于用户的电脑上是否有安装我们定义的字体。在网络上我们经常可以看到国外的一些网站...

    icon通过@font-face实现

    为了解决这些问题,现代网页设计中常常采用`@font-face`规则来实现图标,这种方法被称为图标字体或者符号字体。本篇文章将详细讲解如何通过`@font-face`和CSS3技术来实现icon图标。 `@font-face`是CSS3中引入的一个...

    ubuntu-font-family.tar.gz

    标题中的"ubuntu-font-family.tar.gz"表明这是一款与Ubuntu操作系统相关的字体家族压缩包,采用的是常见的tar.gz格式,这是一种在Linux和Unix系统中广泛使用的文件打包和压缩方式。Ubuntu字体家族是一个开源项目,...

    postcss-font-family-system-ui:PostCSS插件来转换W3C CSS字体系列

    postcss-font-family-system-ui 允许您遵循规范在CSS中使用system-ui 。 body { font : 100 % / 1.5 system-ui;}/* becomes */body { font : 100 % / 1.5 system-ui , -apple-system , Segoe UI , Roboto , Noto ...

    自定义web字体并通过@font-face在网页中嵌入自定义字体

    在上述代码中,`font-family`定义了字体的名称,用于在CSS中引用;`src`属性指定了字体文件的URL以及其格式。`font-weight`和`font-style`分别定义了字体的粗细和倾斜程度,可以根据实际需求进行调整。 一旦定义了`...

    postcss-minify-font-values:使用PostCSS缩小字体声明

    该模块将尝试最小化font-family , font-weight和font速记属性; 它可以在必要时取消对字体系列的引用,检测并删除重复项,并在找到关键字后缩短声明。 有关更多示例,请参见。 h1 { font : bold 2.2 rem/.9 ...

    网页自定义字体CSS-@font-face应用及制作.pdf

    - `YourWebFontName`: 这是你自定义的字体名称,用于在CSS中通过`font-family`属性引用。 - `source`: 指定字体文件的路径,可以是相对路径或绝对路径。多个源文件可以使用逗号分隔。 - `format`: 用于指定字体文件...

Global site tag (gtag.js) - Google Analytics