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之UI元素状态伪类选择器实例演示
Aug 11 HTML / CSS
CSS3教程(4):网页边框和网页文字阴影
Apr 02 HTML / CSS
CSS3教程:边框属性border的极致应用
Apr 02 HTML / CSS
实现CSS3中的border-radius(边框圆角)示例代码
Jul 19 HTML / CSS
CSS Grid布局教程之浏览器开启CSS Grid Layout汇总
Dec 30 HTML / CSS
可自定义箭头样式的CSS3气泡提示框
Mar 16 HTML / CSS
深入理解css属性的选择对动画性能的影响
Apr 20 HTML / CSS
使用CSS3制作版头动画效果
Dec 24 HTML / CSS
HTML5 Web Workers之网站也能多线程的实现
Apr 24 HTML / CSS
HTML5注册页面示例代码
Mar 27 HTML / CSS
HTML5调用手机摄像头拍照的实现思路及代码
Jun 15 HTML / CSS
解决html5中的video标签ios系统中无法播放使用的问题
Aug 10 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 万年历实现代码
2012/10/18 PHP
PHP中使用FFMPEG获取视频缩略图和视频总时长实例
2014/05/04 PHP
CodeIgniter配置之autoload.php自动加载用法分析
2016/01/20 PHP
PHP中获取文件创建日期、修改日期、访问时间的方法
2016/11/05 PHP
PHP自动补全表单的两种方法
2017/03/06 PHP
PHP标准库 (SPL)――Countable用法示例
2020/06/05 PHP
jQuery 技巧大全(新手入门篇)
2009/05/12 Javascript
JQUERY的属性选择符和自定义选择符使用方法(二)
2011/04/07 Javascript
JS实现金额转换(将输入的阿拉伯数字)转换成中文的实现代码
2013/09/30 Javascript
原生js获取元素样式的简单方法
2016/08/06 Javascript
AngularJS报错$apply already in progress的解决方法分析
2017/01/30 Javascript
bootstrap中模态框、模态框的属性实例详解
2017/02/17 Javascript
基于JQuery的购物车添加删除以及结算功能示例
2017/03/08 Javascript
从零开始学习Node.js系列教程之SQLite3和MongoDB用法分析
2017/04/13 Javascript
js前端导出Excel的方法
2017/11/01 Javascript
Vue 组件(component)教程之实现精美的日历方法示例
2018/01/08 Javascript
判断iOS、Android以及PC端的示例代码
2018/11/15 Javascript
浅谈Javascript常用正则表达式应用
2019/03/08 Javascript
JS块级作用域和私有变量实例分析
2019/05/11 Javascript
JS实现的排列组合算法示例
2019/07/16 Javascript
微信小程序返回箭头跳转到指定页面实例解析
2019/10/08 Javascript
Python删除Java源文件中全部注释的实现方法
2017/08/30 Python
python将视频转换为全字符视频
2019/04/26 Python
Python列表倒序输出及其效率详解
2020/03/04 Python
老海军美国官网:Old Navy
2016/09/05 全球购物
聪明的粉丝购买门票的地方:TickPick
2018/03/09 全球购物
意大利时尚奢侈品店:D’Aniello Boutique
2021/01/19 全球购物
服务之星获奖感言
2014/01/21 职场文书
年会搞笑主持词串词
2014/03/24 职场文书
关于成绩下滑的自我检讨书
2014/09/20 职场文书
教师思想作风整顿个人剖析材料
2014/10/10 职场文书
学习十八届四中全会依法治国心得体会
2014/11/03 职场文书
MySQL之高可用集群部署及故障切换实现
2021/04/22 MySQL
React-vscode使用jsx语法的问题及解决方法
2021/06/21 Javascript
纯 CSS 自定义多行省略的问题(从原理到实现)
2021/11/11 HTML / CSS
Python可视化学习之matplotlib内置单颜色
2022/02/24 Python