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 相关文章推荐
全面解析CSS Media媒体查询使用操作(推荐)
Aug 15 HTML / CSS
CSS3+js实现简单的时钟特效
Mar 18 HTML / CSS
css3中单位px,em,rem,vh,vw,vmin,vmax的区别及浏览器支持情况
Dec 06 HTML / CSS
CSS3 对过渡(transition)进行调速以及延时
Oct 21 HTML / CSS
详解使用canvas保存网页为pdf文件支持跨域
Nov 23 HTML / CSS
canvas实现图片马赛克的示例代码
Mar 26 HTML / CSS
html5的画布canvas——画出简单的矩形、三角形实例代码
Jun 09 HTML / CSS
基于HTML5 的人脸识别活体认证的实现方法
Jun 22 HTML / CSS
Canvas 像素处理之改变透明度的实现代码
Jan 08 HTML / CSS
详解通过focusout事件解决IOS键盘收起时界面不归位的问题
Jul 18 HTML / CSS
CSS实现多个元素在盒子内两端对齐效果
Mar 30 HTML / CSS
CSS3常见动画的实现方式
Apr 14 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
聊天室php&mysql(一)
2006/10/09 PHP
PHP求最大子序列和的算法实现
2011/06/24 PHP
php curl post 时出现的问题解决
2014/01/30 PHP
PHP间隔一段时间执行代码的方法
2014/12/02 PHP
PHP针对字符串开头和结尾的判断方法
2016/07/11 PHP
PHP实现的同步推荐操作API接口案例分析
2016/11/30 PHP
php array 转json及java 转换 json数据格式操作示例
2019/11/13 PHP
List Information About the Binary Files Used by an Application
2007/06/18 Javascript
jquery弹出框的用法示例(一)
2013/08/26 Javascript
使用时间戳解决ie缓存的问题
2014/08/20 Javascript
jquery实现增加删除行的方法
2015/02/03 Javascript
浅谈javascript属性onresize
2015/04/20 Javascript
浅谈Javascript中Object与Function对象
2015/09/26 Javascript
JS实现的论坛Ajax打分效果完整实例
2015/10/31 Javascript
全面解析Bootstrap手风琴效果
2020/04/17 Javascript
浅谈JS的基础类型与引用类型
2016/09/13 Javascript
jQuery+CSS3实现四种应用广泛的导航条制作实例详解
2016/09/17 Javascript
JS公共小方法之判断对象是否为domElement的实例
2016/11/25 Javascript
详解JS几种变量交换方式以及性能分析对比
2016/11/25 Javascript
js正则表达式验证表单【完整版】
2017/03/06 Javascript
浅谈 vue 中的 watcher
2017/12/04 Javascript
通过原生vue添加滚动加载更多功能
2019/11/21 Javascript
JS代码简洁方式之函数方法详解
2020/07/28 Javascript
Vuex实现简单购物车
2021/01/10 Vue.js
Python实用日期时间处理方法汇总
2015/05/09 Python
python中__slots__用法实例
2015/06/04 Python
python魔法方法-属性转换和类的表示详解
2016/07/22 Python
Python如何实现机器人聊天
2020/09/10 Python
Python中用xlwt制作表格实例讲解
2020/11/05 Python
html5 制作地图当前定位箭头的方法示例
2020/01/10 HTML / CSS
自荐信范文
2013/12/10 职场文书
2014年银行柜员工作总结
2014/11/12 职场文书
租车协议书
2015/01/27 职场文书
2015婚礼主持词开场白
2015/05/28 职场文书
自动在Windows中运行Python脚本并定时触发功能实现
2021/09/04 Python
Python中如何处理常见报错
2022/01/18 Python