博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
html5字体统一解决方案
阅读量:6313 次
发布时间:2019-06-22

本文共 1286 字,大约阅读时间需要 4 分钟。

背景介绍:

因为项目有涂鸦同步的功能 ( 例如在电脑上画一条直线 需要把这条直线同步到各种端) 所以需要保证h5内容区域在各种设备上都保持一致 众所周知 字体在不同设备平台上 支持程度是不一样的 那么首先需要了解的问题就是字体支持程度。

字体格式的支持程度:

一、TureTpe(.ttf)格式:

.ttf字体是Windows和Mac的最常见的字体,是一种RAW格式,因此他不为网站优化,支持这种字体的浏览器有:

【IE9+,Firefox3.5+,Chrome4+,Safari3+,Opera10+,iOS Mobile Safari4.2+】

二、OpenType(.otf)格式:

.otf字体被认为是一种原始的字体格式,其内置在TureType的基础上,所以也提供了更多的功能,支持这种字体的浏览器有:

【Firefox3.5+,Chrome4.0+,Safari3.1+,Opera10.0+,iOS Mobile Safari4.2+】

三、Web Open Font Format(.woff)格式:

.woff字体是Web字体中最佳格式,他是一个开放的TrueType/OpenType的压缩版本,同时也支持元数据包的分离,支持这种字体的浏览器有: 【IE9+,Firefox3.5+,Chrome6+,Safari3.6+,Opera11.1+】

四、Embedded Open Type(.eot)格式:

.eot字体是IE专用字体,可以从TrueType创建此格式字体,支持这种字体的浏览器有 【IE4+】

五、SVG(.svg)格式:

.svg字体是基于SVG字体渲染的一种格式,支持这种字体的浏览器有 【Chrome4+,Safari3.1+,Opera10.0+,iOS Mobile Safari3.2+】

解决方案:

  1. 在@font-face中我们需要以上五种格式的字体来达到更多种浏览版本的支持。 笔者已知的字体工具转换网址:

    1. https://transfonter.org/
    2. https://www.fontsquirrel.com/tools/webfont-generator

    优点:不依赖第三方。 缺点:字体包资源很大。

  2. 利用webfont中文解决方案 统一各种端的字体。

    优点:动态生成所需字体包,字体资源占用很少。 缺点:依赖第三方。

webfont:

目前国内存在的webfont解决方案:

  1. 有字库: 有字库是全球第一中文 WebFont 服务平台。
  2. 阿里妈妈:阿里系的 WebFont 服务平台。
  3. 就是字: 台湾一家繁体中文 WebFont 服务平台。
  4. 字蛛(FontSpider):一款中文字体压缩器,让网页自由引入中文字体成为可能。希望未来有更多更好的中文 WebFont 解决方案。 就是字 台湾一家繁体中文 WebFont 服务平台。

参考资料:

  1. https://transfonter.org/formats

转载于:https://juejin.im/post/5b0693366fb9a07abf72ebf9

你可能感兴趣的文章
oracle表分区详解
查看>>
网络编程中常见结构体
查看>>
SSL/TLS原理详解
查看>>
Docker 自定义SSH服务镜像
查看>>
JavaScript强化教程 —— Cocos2d-JS自动JSB绑定规则修改
查看>>
configure: error: in `/root/httpd-2.2.11/srclib/apr': c
查看>>
CentOS7搭建Kubernetes-dashboard管理服务
查看>>
buildroot下查找外部编译器通过ext-toolchain-wrapper调用的参数
查看>>
MySQL Replication 主主配置详细说明
查看>>
Linux的任务调度
查看>>
在Android studio中添加jar包方法如下
查看>>
iframe 在ie下面总是弹出新窗口解决方法
查看>>
分享10款漂亮实用的CSS3按钮
查看>>
安装nginx 常见错误及 解决方法
查看>>
Gorun8电子商城
查看>>
在之前链表的基础上改良的链表
查看>>
android编译系统makefile(Android.mk)写法
查看>>
MD5源代码C++
查看>>
Eclipse 添加 Ibator
查看>>
Linux中变量$#,$@,$0,$1,$2,$*,$$,$?的含义
查看>>