问答文章1 问答文章501 问答文章1001 问答文章1501 问答文章2001 问答文章2501 问答文章3001 问答文章3501 问答文章4001 问答文章4501 问答文章5001 问答文章5501 问答文章6001 问答文章6501 问答文章7001 问答文章7501 问答文章8001 问答文章8501 问答文章9001 问答文章9501

关于CSS3 @font-face 中local('☺')的意思

发布网友 发布时间:2022-04-20 15:09

我来回答

7个回答

懂视网 时间:2022-04-20 19:30

  很多人只要一提到@font face规则,心中就会不由自主“哦~~”的一声:“这个我知道,可以用来生成自定义字符小图标!”话是没错,问题在于很多人就以为生成字符小图标就是@font face规则的全部,实际上只是功能之一,如果真正了解@font face规则,你会发现,@font face规则可以做的事情其实非常多,尤其我们不考虑IE7,IE8浏览器的情况下。

  一、 @font face的本质是变量

  虽然说CSS3新世界才出现真正意义上的变量var(参见此文:“了解CSS/CSS3原生变量var”),但实际上,CSS世界中,就已经出现了本质上就是变量的东西,@font face规则就是其中之一,@font face的本质上就是一个定义字体或字体集的变量,这个变量不仅仅是简单的自定义字体,还包括字体重命名,默认字体样式设置等等。

  这个“变量”的意识很重要,有助于我们发挥@font face的潜力,可以让我们的CSS代码更加的精简,更方便的维护等。

  在进入正题之前,我们先要对@font face规则有个大致的面面观。

  @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属性详细介绍

  我们一个一个来介绍:

  1. 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);
}

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

  2. src

  src表示调用字体文件,可以是本地字体文件(IE9+支持),也可以是线上地址(可能有跨域限制)。

  本文主要着重介绍本地字体文件的应用。

  作用1:字体文件名简写

  现在很多网站会使用“微软雅黑”字体,但是,“微软雅黑”的名称有点长:

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

  小手一抖,说不定就拼错了,还要加引号,还要加空格,好麻烦的勒。此时我们就可以利用@font face规则简化,这样就容易记忆了,书写更快了:

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

  使用的时候直接:

.font {
 font-family: YH;
}

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

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

body {
 font-family: PingFangSC-Regular,HelveticaNeue-Light,'Helvetica Neue Light','Microsoft YaHei',sans-serif;
}
.xxxx {
 font-family: PingFangSC-Regular,HelveticaNeue-Light,'Helvetica Neue Light','Microsoft YaHei',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");
}

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

  3. font-style

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

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

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

  由于专门的斜体字不太好找,所以我使用“方正姚体”和“方正舒体”代替做示意。上面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>

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

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

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

@font-face和font-style关系作用示意

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

  4. font-weight

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

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

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

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

.hy-40s,
.hy-50s,
.hy-60s {
 font-family: 'QH';
}
.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>

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

@font-face中font-weight作用示意截图

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

  5. unicode-range

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

微软雅黑的冒号

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

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

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

变成宋体引号后的效果

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

  关于unicode-range更多内容,可参考我之前写的文章“CSS unicode-range特定字符使用font-face自定义字体”。

  三、结束语

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

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

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

  希望本文的内容可以唤起大家对@font-face真正的认识!

热心网友 时间:2022-04-20 16:38

这其实是一个规避异常情况写法,因为浏览器默认会首先检测用户的系统字体是否有和 @font-face 声明的字体同名的字体,如果有就是优先使用系统字体,由于 @font-face 通常是开发者自定义生成的字体,可能和系统字体有差异,所以可以使用 src: local('☺') 来规避,因为 OpenType 协议规定字体名字中含有双字节 unicode 字符会被视作非法,所以这个笑脸就是用来让浏览器不匹配到任何系统字体,从而规避 @font-face 字体可能和系统字体重名而造成的问题

热心网友 时间:2022-04-20 17:56

目的是保护IE浏览器。如果没有这句,IE会尝试将第二个src描述符的值读作一个路径,并向服务器发出一个额外的、无用的请求。特地写了第一个src的目的也是为了保证IE能读到正确路径。。。具体可参看《CSS3实用指南》ZM. Gillenwater. 页码P112-P114.
顺便说一下我是搜local()语法跑来的...

热心网友 时间:2022-04-20 19:31

src:

远程字体文件位置的URL或者用户计算机上的字体名称, 可以使用local语法通过名称指定用户的本地计算机上的字体( i.e. src: local('Arial'); )。 如果找不到该字体,将会尝试其他来源,直到找到它。(取自:网页链接,你可以看下,或许对你有帮助。)

我是这么理解的:
他应该是调用本地括号内名字的字体的意思,你自己电脑上可能安装了这个字体,所以没事,但是放到服务器上后,服务器上是没用这个字体的,所以没用。

热心网友 时间:2022-04-20 21:22

参考这篇文章
http://www.w3cplus.com/content/css3-font-face

热心网友 时间:2022-04-20 23:30

看不懂

热心网友 时间:2022-04-21 01:55

有点复杂。
声明声明:本网页内容为用户发布,旨在传播知识,不代表本网认同其观点,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。E-MAIL:11247931@qq.com
初中英语语法讲解:名词所有格 关于名词所有格一问 暗区突围画面怎么设置最好-暗区突围画面设置推荐 暗区突围打开的箱子怎么关上 保险箱关闭攻略 暗区突围 暗区突围画面设置怎么弄最佳? 暗区突围 暗区突围光影怎么调? 暗区突围 暗区突围中间白点怎么设置? 暗区突围灵敏度怎么调最稳 暗区突围灵敏度最佳设置方法 我的WIN7 64位系统无法安装打印机HP1136,请支持啊,急。驱动下载也没用... win7电脑连接不上惠普打印机Win7系统安装不了惠普HP1007打印机 微信升级的验证码如何获取 注册新浪博客时,可以收到验证码,拉动滑块结束后,总是显示正在升级当中,怎么办呢? 我登陆手机号时 点获取验证码 上边显示非移动号码服务专区升级版本中是怎么回事? 您好:我的手机今天才买的,我登录微信,总是提醒需要获取手机验证码或者升级版本,按确定以后,如何操作 家里安装好监控后又打电话要验证码给监控升级怎么回事?家里安装监控有段时间了,今天突然有人用电信手机_百度问一问 男人眉毛短,就是寿命短吗? 要验证码免费升级,宽带是真的吗? 眉毛短粗好吗 男生眉毛短说明什么 眉头短什么意思 眉毛短的人性格什么特点? 眉毛比眼睛短 喷墨打印机长期不用,应该怎么保养 打印机如何保养 喷墨打印机暑假断电两个月不用如何保养? 用iphone自带的浏览器看电影会不会产生垃圾 苹果手机,想看最新的电影,用什么播放器 苹果有传门看片的播放器 100升热水器,要几个平方的线 100升的热水器可以供两个洗头床不 “寂静”和“静寂”的区别是什么? 静寂和寂静有什么区别 沉寂和静寂的共同点,不同点及用法是什么? 静寂沉寂枯寂的区别 两岁半孩子流鼻血是怎么回事 小孩两岁多流鼻血是怎么回事 铁杆山药放绿还能吃吗 铁棍山药切好后会显铁锈色 铁棍山药为什么发紫 会计凭证遗失了一本怎么办? 财务管理系统记账凭证生成表格形式提示找不到记账凭证 我的一本记帐凭证丢了怎么办 原始记账凭证丢失了,总共有6个月的财务资料 昨天我把一本去年的记帐凭证弄丢了,怎么办? 登记帐薄之后,记账凭证丢了怎么弄 会计凭证丢失,怎么办?急啊!!! 爱护铁路确保安全珍爱身命征文1300字 爱路,护路,共筑平安铁路的征文怎么写 (原创)安全生产月演讲稿 2012年安全月征文比赛 安全演讲稿范文(最新) 全麦南瓜饼怎么做