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实现跳动的动画效果
Sep 12 HTML / CSS
CSS3使用多列制作瀑布流
May 10 HTML / CSS
css3 clip实现圆环进度条的示例代码
Feb 07 HTML / CSS
css3实现椭圆轨迹旋转的示例代码
Oct 29 HTML / CSS
css3遮罩层镂空效果的多种实现方法
May 11 HTML / CSS
HTML5实现经典坦克大战坦克乱走还能发出一个子弹
Sep 02 HTML / CSS
html5的自定义data-*属性与jquery的data()方法的使用
Jul 02 HTML / CSS
AmazeUI 折叠面板的实现代码
Aug 17 HTML / CSS
html css3不拉伸图片显示效果
Jun 07 HTML / CSS
关于CSS浮动与取消浮动的问题
Jun 28 HTML / CSS
使用canvas对video视频某一刻截图功能
Sep 25 HTML / CSS
HTML5中的DOCUMENT.VISIBILITYSTATE属性详解
May 07 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实现文件下载功能的几个代码分享
2014/05/10 PHP
PHP中的self关键字详解
2019/06/23 PHP
Display SQL Server Login Mode
2007/06/21 Javascript
JavaScript DOM学习第六章 表单实例
2010/02/19 Javascript
ajax 缓存 问题 requestheader
2010/08/01 Javascript
ASP.NET jQuery 实例3 (在TextBox里面阻止复制、剪切和粘贴事件)
2012/01/13 Javascript
jquery动画2.元素坐标动画效果(创建一个图片走廊)
2012/08/24 Javascript
jQuery布局插件UI Layout简介及使用方法
2013/04/03 Javascript
jquery iframe操作详细解析
2013/11/20 Javascript
js 验证身份证信息有效性
2014/03/28 Javascript
js用typeof方法判断undefined类型
2014/07/15 Javascript
JS实现灵巧的下拉导航效果代码
2015/08/25 Javascript
javascript中的正则表达式使用详解
2015/08/30 Javascript
JavaScript阻止回车提交表单的方法
2015/12/30 Javascript
node.js实现回调的方法示例
2017/03/01 Javascript
Bootstrap警告(Alerts)的实现方法
2017/03/22 Javascript
对layui中表单元素的使用详解
2018/08/15 Javascript
使用layui日期控件laydate对开始和结束时间进行联动控制的方法
2019/09/06 Javascript
vue实现公共方法抽离
2020/07/31 Javascript
微信小程序实现点赞业务
2021/02/10 Javascript
Python socket C/S结构的聊天室应用实现
2014/11/30 Python
详解如何利用Cython为Python代码加速
2018/01/27 Python
python 解决动态的定义变量名,并给其赋值的方法(大数据处理)
2018/11/10 Python
让Python脚本暂停执行的几种方法(小结)
2019/07/11 Python
30秒学会30个超实用Python代码片段【收藏版】
2019/10/15 Python
python中的 zip函数详解及用法举例
2020/02/16 Python
python+requests接口压力测试500次,查看响应时间的实例
2020/04/30 Python
Keras设定GPU使用内存大小方式(Tensorflow backend)
2020/05/22 Python
如何导出python安装的所有模块名称和版本号到文件中
2020/06/05 Python
使用Python爬虫爬取小红书完完整整的全过程
2021/01/19 Python
python爬取youtube视频的示例代码
2021/03/03 Python
纯CSS和jQuery实现的在页面顶部显示的进度条效果2例(仿手机浏览器进度条效果)
2014/04/16 HTML / CSS
敏捷开发的主要原则都有哪些
2015/04/26 面试题
大学运动会通讯稿
2014/01/28 职场文书
学习标兵获奖感言
2014/02/20 职场文书
2016寒假假期总结
2015/10/10 职场文书