Html5自定义字体解决方法


Posted in HTML / CSS onOctober 09, 2019

应用情景

业务搬砖需求需要用原设计稿给出的字体,使用@font-face引入后,发现字体包太大10M左右,每次请求服务器10M流量会造成服务器压力,影响用户体验

第一步:使用@font-face

MDN概述

这是一个叫做@font-face 的CSS @规则 ,它允许网页开发者为其网页指定在线字体。 通过这种作者自备字体的方式,@font-face 可以消除对用户电脑字体的依赖。 @font-face 不仅可以放在在CSS的最顶层, 也可以放在 @规则 的 条件规则组 中。

简单来说就是可以在网页上用自己的字体包 可以放在类似@media媒体查询等@规则中

用法

@font-face CSS at-rule 指定一个用于显示文本的自定义字体;字体能从远程服务器或者用户本地安装的字体加载. 如果提供了local()函数,从用户本地查找指定的字体名称,并且找到了一个匹配项, 本地字体就会被使用. 否则, 字体就会使用url()函数下载的资源。

通过允许作者提供他们自己的字体,@font-face 让设计内容成为了一种可能,同时并不会被所谓的"网络-安全"字体所限制(字体如此普遍以至于它们能被广泛的使用). 指定查找和使用本地安装的字体名称可以让字体的自定义化程度超过基本字体,同时在不依赖网络情况下实现此功能。

在同时使用url()和local()功能时,为了用户已经安装的字体副本在需要使用时被使用,如果在用户本地没有找到字体副本就会去使用户下载的副本查找字体。
@font-face 规则不仅仅使用在CSS的顶层,还可以用在任何CSS条件组规则中.

简单来说就是@font-face 突破网络安全限制,可以让作者自由使用自己想要的字体,可以用在任何css条件组规则中,这里不对其local()函数做额外延伸。

下面贴一个日常用法

@font-face {
  font-family: "Open Sans";
  src: url("/fonts/OpenSans-Regular-webfont.woff2") format("woff2"),//后缀是字体文件格式 常见有ttf svg等
       url("/fonts/OpenSans-Regular-webfont.woff") format("woff");
}

这里提供一个在线字体转化网站字体格式转化

第二步:字体包压缩

成功引入后,就发现字体包太大了,这里就涉及字体包压缩,使用一个字体包压缩器 font-spider。

font-spider使用

基本原理

通过匹配html中用到的文体,删除剩余没有用到的文字。达到压缩字体包的目的。

安装

npm install font-spider -g

没有安装node npm的同学,请寻找安装方法

使用

@font-face {
    font-family: mysimhei;
    src: url(../../../simhei.ttf);
}
p{
    font-family: mysimhei;
}

注意如果使用要在css文件中先这样引入

font-spider ./demo/*.html

这里的*号是表示匹配全部 也可指定html。

font-spider ./demo/*.html ./demo/pages/index.html

多文件的话用空格分开

压缩完成

会生成一份备份字体文件与压缩后的字体包

Html5自定义字体解决方法

闲谈

其实是对接香港业务,香港的win10操作系统竟然没有黑体,客户觉得字体不一样影响体验,上字体包又太大,所以找出这一套上字体连压缩的解决方法。(卑微实习生)

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

HTML / CSS 相关文章推荐
CSS3中动画属性transform、transition和animation属性的区别
Sep 25 HTML / CSS
CSS3伪类选择器:nth-child()
Apr 02 HTML / CSS
CSS3制作日历实现代码
Jan 21 HTML / CSS
基于css3实现漂亮便签样式
Mar 18 HTML / CSS
css3学习心得分享
Aug 19 HTML / CSS
CSS3制作炫酷带方向感应的鼠标滑过图片3D动画
Mar 16 HTML / CSS
CSS3实现同时执行倾斜和旋转的动画效果
Oct 27 HTML / CSS
css3加js做一个简单的3D行星运转效果实例代码
Jan 18 HTML / CSS
利用CSS3实现文字折纸效果实例代码
Jul 10 HTML / CSS
简单介绍HTML5中的文件导入
May 08 HTML / CSS
Html5移动端适配IphoneX等机型的方法
Jun 25 HTML / CSS
移动端HTML5开发神器之vconsole详解
Dec 15 HTML / CSS
webView加载html图片遇到的问题解决
Oct 08 #HTML / CSS
使用postMessage让 iframe自适应高度的方法示例
Oct 08 #HTML / CSS
基于 HTML5 WebGL 实现的医疗物流系统
Oct 08 #HTML / CSS
html2canvas生成清晰的图片实现打印的示例代码
Sep 30 #HTML / CSS
html5视频媒体标签video的使用方法及完整参数说明详解
Sep 27 #HTML / CSS
Html5实现首页动态视频背景的示例代码
Sep 25 #HTML / CSS
HTML5自定义元素播放焦点图动画的实现
Sep 25 #HTML / CSS
You might like
jQuery实现单行文字间歇向上滚动源代码
2013/06/02 Javascript
js点击选择文本的方法
2015/02/09 Javascript
js实现模拟计算器退格键删除文字效果的方法
2015/05/07 Javascript
将页面table内容与样式另存成excel文件的方法
2015/08/05 Javascript
jQuery实现的图文高亮滚动切换特效实例
2015/08/10 Javascript
详解javascript传统方法实现异步校验
2016/01/22 Javascript
js轮播图无缝滚动效果
2017/06/17 Javascript
jquery根据name取得select选中的值实例(超简单)
2018/01/25 jQuery
vue+canvas实现炫酷时钟效果的倒计时插件(已发布到npm的vue2插件,开箱即用)
2018/11/05 Javascript
Vue 理解之白话 getter/setter详解
2019/04/16 Javascript
webpack优化之代码分割与公共代码提取详解
2019/11/22 Javascript
vue element ui validate 主动触发错误提示操作
2020/09/21 Javascript
[44:10]2018DOTA2亚洲邀请赛 4.5 淘汰赛 EG vs VP 第一场
2018/04/06 DOTA
Python学习教程之常用的内置函数大全
2017/07/14 Python
Python3安装Scrapy的方法步骤
2017/11/23 Python
django rest framework 数据的查找、过滤、排序的示例
2018/06/25 Python
numpy返回array中元素的index方法
2018/06/27 Python
Python实现定时执行任务的三种方式简单示例
2019/03/30 Python
pandas.cut具体使用总结
2019/06/24 Python
python对绑定事件的鼠标、按键的判断实例
2019/07/17 Python
python单向循环链表原理与实现方法示例
2019/12/03 Python
python利用JMeter测试Tornado的多线程
2020/01/12 Python
解决tensorboard多个events文件显示紊乱的问题
2020/02/15 Python
python中for in的用法详解
2020/04/17 Python
pandas数据选取:df[] df.loc[] df.iloc[] df.ix[] df.at[] df.iat[]
2020/04/24 Python
三个Unix的命令面试题
2015/04/12 面试题
春季运动会广播稿大全
2014/02/19 职场文书
2014年社会实践活动总结范文
2014/04/29 职场文书
2014党员学习兰辉先进事迹思想汇报
2014/09/17 职场文书
离职信范文
2015/06/23 职场文书
一文搞懂Python Sklearn库使用
2021/08/23 Python
基于PyQT5制作一个桌面摸鱼工具
2022/02/15 Python
MYSQL优化之数据表碎片整理详解
2022/04/03 MySQL
MySQL时区造成时差问题
2022/04/13 MySQL
Mysql数据库group by原理详解
2022/07/07 MySQL
HttpClient实现表单提交上传文件
2022/08/14 Java/Android