CSS3の@font faceルールの解析

不言
不言オリジナル
2018-06-20 17:54:281730ブラウズ

この記事では主に CSS3 の背景にある @font face ルールを紹介します。興味のある方は参考にしてください。

@font face ルールについて言及されると、「ああ」と感じずにはいられない人も多いでしょう。 ~~": 「これは知っています。カスタム文字アイコンの生成に使用できます!」 その通りです。問題は、多くの人が、小さな文字アイコンの生成が @font face ルールのすべてであると考えていることです。実際、それは 1 つのルールにすぎません。その機能の最大の特徴は、@font face ルールを本当に理解していれば、特に IE7 と IE8 ブラウザーを考慮しない場合、@font face ルールで実際に多くのことができることがわかるということです。

1. @font faceの本質は変数です

実際の変数varはCSS3の新しい世界に登場したと言われていますが(こちらの記事「CSS/CSS3ネイティブ変数varを理解する」を参照)実際、CSS の世界では、本質的に変数であるものがすでに登場しています。 @font face ルールは、本質的にはフォントまたはフォント セットを定義する変数です。カスタム フォントには、フォントの名前変更、デフォルトのフォント スタイル設定などが含まれます。

この「変数」を認識することは非常に重要であり、@font face の可能性を理解するのに役立ち、CSS コードをより合理化して保守しやすくすることができます。

本題に入る前に、まず @font face ルールの概要を理解する必要があります。

@font face このルールでサポートされている CSS プロパティは次のとおりです: font-family src font-weight font-style unicode-rangefont-variant font-stretch font -機能 -設定 。例: @font face 规则支持的CSS属性有: font-family src font-weight font-style unicode-range font-variant font-stretch font-feature-settings 。例如:

@font-face {
  font-family: 'example';
  src: url(example.ttf);
  font-style: normal;
  font-weight: normal;
  unicode-range: U+0025-00FF;
  font-variant: small-caps;
  font-stretch: expanded;
  font-feature-settings:"liga1" on;
}

属性还是挺多的,而且有些属性,估计是他认识你,你不认识他。但是从实用角度来讲,有些属性其实可以不用去深究,例如 font-variant , font-stretch , font-feature-settings 这 3 个属性。为什么呢?因为按照我的经验理解,这 3 个属性给我感觉更像是专为英文设计的,所以如果不是有业务需要,可以先放一放。

好,现在,是不是感觉压力一下子小了很多,我们需要在意的可以自定义的属性就只剩下下面这些:

@font-face {
  font-family: 'example';
  src: url(example.ttf);
  font-style: normal;
  font-weight: normal;
  unicode-range: U+0025-00FF;
}

估计会有小伙伴疑惑 @font-face 规则中的 font-style , font-weight 以及 unicode-range 这些属性有什么用,尤其 font-style , font-weight ,好像就是专门过来打酱油的。实际上,这里的每个属性都不是泛泛之辈,都是有故事的人。

在介绍每个属性之前,有必要郑重声明一下,接下来有大量的案例,全是基于 local 本地字体做示意的,而IE7,IE8浏览器是不支持 local 本地字体的,所以,本文的标题是“CSS3背景下的……”,就是这么个原因,大家注意明辨,如果你的项目还需要兼容IE8,本文介绍,这些好东西可能就需要斟酌斟酌了。

二、 @font face常用CSS属性详细介绍

我们一个一个来介绍:

font-family

这里的 font-family 可以看成是一个字体变量,名称可以非常随意,例如直接一个美元符号 '$' ,例如:

@font-face {
  font-family: '$';
  src: local("Microsoft Yahei");
}

这时候,对普通HTML元素,你设置其 font-family 属性值为 '$' ,则其字体表现就变成了“微软雅黑”(如果本地有这个字体)。

甚至非IE浏览器下可以直接使用纯空格 ' ' ,不过有一点需要注意,就是使用这些稀奇古怪的字符或者有空格的时候,一定要加引号。

虽然说自己变量名可以很随意,但是有一类名称,不能随便设置,就是原本系统就有的字体名称,例如下面的代码:

@font-face {
  font-family: 'Microsoft Yahei';
  src: local(SimSun);
}

从此“微软雅黑”字体就变成了“宋体”。当然,有时候我们说不定就需要这种覆盖,比如说新来了一个设计主管,平生最看不惯“微软雅黑”,希望换成其他字体,这个时候我们就可以使用这个变量覆盖轻轻松松完成整站的字体变更。

src

src

.font {
    font-family: 'Microsoft Yahei';
}

かなり多くの属性があり、一部の属性は、彼はあなたのことを知っているが、あなたは彼のことを知らないことを意味する場合があります。ただし、実際的な観点から見ると、font-variant、font-stretch、font-feature-settings などの一部の属性は詳細に検討する必要はありません。なぜ?私の経験によれば、これら 3 つの属性は英語向けに設計されているように感じられるため、ビジネス上の必要がない場合は、最初に脇に置いておいても問題ありません。

さて、突然プレッシャーがかなり軽減されたように感じませんか? 私たちが注意する必要がある唯一のカスタマイズ可能な属性は次のとおりです:

@font-face {
  font-family: YH;
  src: local("Microsoft Yahei");
}

混乱している友達もいると思います。 @font-face ルール その中の font-style、font-weight、unicode-range 属性、特に font-style と font-weight はどのような用途に使用されますか。これらは醤油を作るために特別に使用されているようです。実はここでの属性はどれも単なる一般人ではなく、ストーリーのある人物です。

各属性を紹介する前に、すべてローカル フォントに基づいた多数のケースが存在し、IE7 および IE8 ブラウザーはローカル フォントをサポートしていないことを厳粛に宣言する必要があります。そのため、この記事のタイトルは「In the context」です。この記事で紹介しているように、プロジェクトが IE8 と互換性を持つ必要がある場合は、これらの利点を考慮する必要がある可能性があります。

2. @font face の一般的に使用される CSS プロパティの詳細な紹介🎜🎜🎜🎜それらを 1 つずつ紹介します: 🎜🎜🎜font-family🎜🎜🎜 ここでの font-family は、フォント変数であり、名前は非常に任意にできます。たとえば、直接ドル記号「$」を使用できます。例: 🎜🎜🎜
.font {
    font-family: YH;
}
🎜🎜🎜 この時点で、通常の HTML 要素の場合は、その font-family を設定します。 属性値を '$' に設定すると、フォント表現は「Microsoft Yahei」になります (このフォントがローカルで利用可能な場合)。 🎜🎜IE 以外のブラウザでは純粋なスペース <code> ' ' を直接使用することもできますが、注意する必要があるのは、これらの奇妙な文字やスペースを使用する場合は引用符を追加する必要があることです。 🎜🎜変数名は任意で構いませんが、以下のコードのように、システムにもともと存在するフォント名など、気軽に設定できないタイプの名前があります。 、フォント「Microsoft Yahei」が「Song Ti」になりました。もちろん、場合によってはこのような対応が必要になる場合もあります。たとえば、新しいデザイン マネージャーが入ってきて、人生で最も「Microsoft Yahei」が嫌いな場合、現時点ではこれを使用できます。可変範囲を簡単に設定 サイト全体のフォント変更を簡単に完了できます。 🎜🎜🎜src🎜🎜🎜src は、ローカル フォント ファイル (IE9 以降でサポートされている) またはオンライン アドレス (クロスドメイン制限がある場合があります) のいずれかのフォント ファイルを呼び出すことを意味します。 🎜🎜この記事は主にローカル フォント ファイルの適用に焦点を当てています。 🎜🎜機能 1: フォント ファイル名の略称🎜🎜現在、多くの Web サイトで「Microsoft Yahei」フォントが使用されていますが、「Microsoft Yahei」の名前は少し長いです: 🎜🎜🎜
body {
    font-family: PingFangSC-Regular,HelveticaNeue-Light,&#39;Helvetica Neue Light&#39;,&#39;Microsoft YaHei&#39;,sans-serif;
}
.xxxx {
    font-family: PingFangSC-Regular,HelveticaNeue-Light,&#39;Helvetica Neue Light&#39;,&#39;Microsoft YaHei&#39;,sans-serif;
}
🎜🎜🎜小さな手を振って、多分あなたはそれを綴ることができます 間違っています、引用符とスペースを追加する必要があり、これは本当に面倒です。この時点で、@font face を使用してルールを簡素化することができます。これにより、覚えやすく、より速く書くことができます: 🎜🎜🎜
@font-face {
  font-family: BASE;
  src: local("HelveticaNeue-Light"), local("Helvetica Neue Light"),  local("PingFang SC"), local("Microsoft YaHei"), local(sans-serif);
}
🎜🎜🎜直接使用してください: 🎜

.font {
    font-family: YH;
}

多么干净,多么清爽,心情多么舒畅!

src 还支持多个 local 字体地址同时出现,嘿,这简化的CSS代码可不是一个字体名了,而是一大波字体名称了,例如某网站使用了大量类似下面的 font-family 属性值:

body {
    font-family: PingFangSC-Regular,HelveticaNeue-Light,&#39;Helvetica Neue Light&#39;,&#39;Microsoft YaHei&#39;,sans-serif;
}
.xxxx {
    font-family: PingFangSC-Regular,HelveticaNeue-Light,&#39;Helvetica Neue Light&#39;,&#39;Microsoft YaHei&#39;,sans-serif;
}

虽然说,实现的时候,借助了Sass, Less之类工具让字体名称们成为了变量,写代码的时候好像也没怎么吃力,但是最终生成的CSS其实是比较啰嗦,如果我们走本质上就是变量的 @font face ,是不是不仅开发简单,代码也简单了,如下处理:

@font-face {
  font-family: BASE;
  src: local("HelveticaNeue-Light"), local("Helvetica Neue Light"),  local("PingFang SC"), local("Microsoft YaHei"), local(sans-serif);
}

于是我们用字体的时候直接:

body {
    font-family: BASE;
}
.xxxx {
    font-family: BASE;
}

看语义又好,代码又简单,实用又方便,超级使用的小技巧。

当然, local 本地作用还不止这些。

业界有个名为“ 字蛛 ”的中文字体处理工具,可以提取页面中使用的特殊中文字体并生成新的体积更小的自定义字体。我们可以在这个基础上更进一步,举个例子:

一些特殊的标题设计师就是喜欢用“方正粗雅宋”这个字体(已经购得版权),但是很显然,这么帅气的字体,几乎很少有用户安装的,所以实际开发的时候,全都是通过工具而生成一个全新的精简版的“方正粗雅宋”字体文件,再通过 src 属性 url() 方法外链这个字体文件。

很棒的方案,但还不够完美,为什么呢?虽然安装“方正粗雅宋”这个字体的用户并不多,但并不表示没有用户使用之。试想一下,假如有用户安装了这个字体,结果你在网页呈现的时候,还要再去外链一个额外的文件地址,岂不是白白的浪费?既浪费流量,体验又不一定好,如果字体文件加载慢,会看到文字“变形”的过程,显然是不友好的。

我们可以借助 @font face 规则中的 local 实现代码和体验上的进一步的提升,如下:

@font-face {
  font-family: FZCYS;
  src: local("FZYaSongS-B-GB"), 
       url("FZCYS.woff2"),  
       url("FZCYS.woff"),
       url("FZCYS.ttf");
}

于是乎,那些安装了“方正粗雅宋”这个字体的用户,就没有任何字体文件请求。加载更快了,用户体验上升了,还省了流量,如此百益无一害的事情,还不妥妥的用起来。

font-style

在Chrome浏览器下, @font face 规则设置 font-style:italic 可以让文字倾斜,但是这并不是其作用所在。

@font face 规则中的 font-style font-weight 类似,都是用来设置对应字体样式或自重下该使用什么字体。因为有些字体可能会有专门的斜体字,注意这个斜体字,并不是让文字的形状倾斜,而是专门设计的倾斜的字体,很多细节会跟物理上的请求不一样。于是,我在CSS代码中使用 font-style:italic 的时候,就会调用这个对应字体,如下示意:

@font-face {
  font-family: &#39;I&#39;;
  font-style: normal;
  src: local(&#39;FZYaoti&#39;);
}
@font-face {
  font-family: &#39;I&#39;;
  font-style: italic;
  src: local(&#39;FZShuTi&#39;);
}

由于专门的斜体字不太好找,所以我使用“方正姚体”和“方正舒体”代替做示意。上面CSS代码我解读一下:制定一个字体,名叫 'I' ,当文字样式正常的时候,字体表现使用“方正姚体”,当文字设置了 font-style:italic 的时候,字体表现为“方正舒体”。

好,现在假设有下面这样的CSS和HTML:

.i {
  font-family: I;
}

<p><i class="i">类名是i,标签是i</i></p>
<p><span class="i">类名是i, 标签是span</span></p>

请问最终的表现是怎样的?

由于 5a8028ccc7a7e27417bff9f05adf5932 标签天然 font-style:italic ,因此理论上,上面一行文字表现为“方正舒体”,下面一行为“方正姚体”,最终结果是如何呢?

当当当当,完全符合,如下截图:

这下大家应该明白, @font face 规则中的 font-style 是干嘛用的了吧。

font-weight

font-weight font-style 类似,不过是定义了不同字重使用不同字体,对于中午而言,这个要比 font-style 适用性强很多。我这里就有一个非常具有代表性的例子,版权字体“汉仪旗黑”自重非常丰富,但是这个字体不像“思源黑体”,天然可以根据 font-weight 属性值加载对应的字体文件,怎么办呢?很简单,使用 @font face规则重新定义一下即可,例如下面的CSS代码:

@font-face {
  font-family: &#39;QH&#39;;
  font-weight: 400;
  src: local(&#39;HYQihei 40S&#39;);
}
@font-face {
  font-family: &#39;QH&#39;;
  font-weight: 500;
  src: local(&#39;HYQihei 50S&#39;);
}
@font-face {
  font-family: &#39;QH&#39;;
  font-weight: 600;
  src: local(&#39;HYQihei 60S&#39;);
}

解读一下就是,是一个全新的字体,名为 'QH' ,当字重 font-weight 为 400 的时候,使用“汉仪旗黑 40S”字重字体,为 500 的时候,使用“汉仪旗黑 50S”字重字体,为 600 的时候,使用“汉仪旗黑 60S”字重字体。

于是乎,当我们应用如下的CSS和HTML代码的时候:  

.hy-40s,
.hy-50s,
.hy-60s {
  font-family: &#39;QH&#39;;
}
.hy-40s {
  font-weight: 400;
}
.hy-50s {
  font-weight: 500;
}
.hy-60s {
  font-weight: 600;
}

<ul>
  <li class="hy-40s">汉仪旗黑40s</li>
  <li class="hy-50s">汉仪旗黑50s</li>
  <li class="hy-60s">汉仪旗黑60s</li>
</ul>

我们就可以看到,文字粗细错落有致的效果,如下截图:

如果用在网页开发中,必定会让我们的界面更加的细腻,设计更加的精致,视觉更加的愉悦。

unicode-range

unicode-range 的作用是可以让特定的字符或者字符片段使用特定的字体。举个例子,下图是文字应用了“微软雅黑”字体后的效果:

但是,这两个“引号”左右间隙不均,方向不明,实在是看着不爽,此时我们就专门指定这两个“引号”使用其他字体,如下CSS:

@font-face {
  font-family: BASE;
  src: local("Microsoft Yahei");
}
@font-face {
  font-family: quote;
  src: local(&#39;SimSun&#39;);    
  unicode-range: U+201c, U+201d;
}
.font {
    font-family: quote, BASE;
}

然后效果就变成这样子了:

嗯,一下子变得舒服多了。

三、结束语

根据我个人的感觉, @font-face 的为人所知要得益于icon fonts小图标技术。因为自定义的小图标字体几乎一定是外链的,而恰恰好,低版本IE7,IE8浏览器的 src 只能是 url() 外部字体文件。外加矢量、颜色可控等特性,于是成为了兼容时代最好的小图标解决方案,可谓功不可没,但也带来了另外一个弊端,让很多同学误以为 @font-face 除了自定义一些小图标之外就一无是处了。于是,当越来越多产品和项目不需要兼容IE7,IE8浏览器的时候,由于有更好的SVG图标解决方案, @font-face 似乎又很少被提及了。

通过本文的一些介绍,大家应该感觉到 @font-face 规则的作用被严重低估了,除了小图标外, @font-face 还能做的事情非常多,而这些事情,才更像是 @font-face 应该做的事情。

就算你的项目需要兼容IE8,本文介绍的一些特性也是可以渐进增强使用的,例如特殊中文字体优先使用本地字体,或者 unicode-range 特定字符使用特定字体等。

以上就是本文的全部内容,希望对大家的学习有所帮助,更多相关内容请关注PHP中文网!

相关推荐:

如何利用CSS3伪元素实现逐渐发光的方格边框

以上がCSS3の@font faceルールの解析の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。