您现在的位置是:网站首页> 编程资料编程资料
Html5自定义字体解决方法html5 canvas绘制网络字体的常用方法使用HTML5 Canvas API控制字体的显示与渲染的方法HTML5时代CSS设置漂亮字体取代图片
2021-08-31
1210人已围观
简介 这篇文章主要介绍了Html5自定义字体解决方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
应用情景
业务搬砖需求需要用原设计稿给出的字体,使用@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
多文件的话用空格分开
压缩完成
会生成一份备份字体文件与压缩后的字体包

闲谈
其实是对接香港业务,香港的win10操作系统竟然没有黑体,客户觉得字体不一样影响体验,上字体包又太大,所以找出这一套上字体连压缩的解决方法。(卑微实习生)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
相关内容
- webView加载html图片遇到的问题解决HTML5 图片预加载的示例代码利用简洁的图片预加载组件提升html5移动页面的用户体验 html5实现的页面滚动图片动画加载特效源码HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影基于HTML代码实现图片碎片化加载功能
- 使用postMessage让 iframe自适应高度的方法示例web响应式布局中iframe自适应的方法iframe 多层嵌套 无限嵌套 高度自适应的解决方案网页设计技巧:iframe自适应高度的问题iframe标签用法详解(属性、透明、自适应高度)三谈Iframe自适应高度代码Iframe 高度自适应(兼容IE/Firefox、同域/跨域)iframe 自适应大小实现代码
- 基于 HTML5 WebGL 实现的医疗物流系统HTML5播放实现rtmp流直播html5用video标签流式加载的实现Html5 实现微信分享及自定义内容的流程HTML5 canvas 瀑布流文字效果的示例代码HTML5移动端手机网站开发流程HTML5实现的图片无限加载的瀑布流效果另带边框圆角阴影HTML5梦幻之旅——炫丽的流星雨效果实现过程HTML5 离线应用之打造零请求、无流量网站的解决方法Html5之webcoekt播放JPEG图片流
- html2canvas生成清晰的图片实现打印的示例代码html2 canvas生成清晰的图片实现打印功能前端实现打印图像功能一个不错的html 打印代码支持翻页CSS2 打印属性让打印HTML文档不出问题将XHTML CSS页面转换为打印机页面将XHTML CSS页面转换为打印机页面html 打印相关操作与实现详解
- 吃透移动端 Html5 响应式布局html5移动端自适应布局的实现HTML5 通过Vedio标签实现视频循环播放的示例代码HTML5中在title标题标签里设置小图标的方法html5用video标签流式加载的实现详解HTML5 Canvas标签及基本使用html5自定义video标签的海报与播放按钮功能详解HTML5布局和HTML5标签
- HTML文本属性&颜色控制属性的实现html5实现点击弹出图片功能html5 录制mp3音频支持采样率和比特率设置html5表单的required属性使用html5调用摄像头实例代码HTML5页面音频自动播放的实现方式Html5大屏数据可视化开发的实现html实现弹窗的实例HTML5来实现本地文件读取和写入的实现方法HTML 罗盘式时钟的实现HTML5简单实现添加背景音乐的几种方法
- 吃透移动端 1px的具体用法postcss-pxtorem移动端适配的实现移动端适配 使px自动转换remHtml5移动端适配IphoneX等机型的方法浅谈移动端适配大法html5实现移动端适配完美写法详解如何使用rem或viewport进行移动端适配
- 关于html字符串正则判断和匹配的具体使用html中的图片直接使用base64编码后的字符串代替基于HTML5 Canvas:字符串,路径,背景,图片的详解
- 处理textarea中的换行和空格如何让pre和textarea等HTML元素去掉滚动条自动换行自适应文本内容高度用CSS实现textArea中的placeholder换行功能关于textarea文本转为html即回车换行HTML里面Textarea换行问题总结如何在textarea文本输入区内实现换行
- VSCode 自定义html5模板的实现vscode怎么设置html标签自动补全? vscode自动补全html的技巧解决vscode 中保存后html自动格式化的问题VSCode怎么安装插件运行HTML文件?SublimeText3怎么快速输入html5格式?Sublime Text2怎么新建一个HTML头部文件?sublime / vscode 快捷生成HTML代码的实现
