资料:
关于新发布的google web font 官方介绍
,包括三个部分:
get started
:介绍了最简单的直接css引用方法,包括多字体,粗体斜体的打包应用。
WebFont Loader
:面向javascript开发者,通过 自定义事件以及状态css类名的动态添加 提供了细力度的控制字体加载过程,今天主要是研究一下实现这一功能的字体下载js库。
Technical Considerations
:介绍了web font的基本原理,并提醒了各个浏览器的差异:firefox会先显示默认字体,待自定义字体下载完毕后再重新渲染为自定义字体,即"flash of unstyled text",而其他浏览器则表现为自定义字体下载完成前对应字体文字是空白。
w3c 的对应标准
web font历史以及浏览器差异
:ie选择了具备版权保护功能的eot(Embedded OpenType)字体格式,而其他浏览器则选择了 很开放的OpenType。
WebFont Loader:
测试演示
(目前firefox@mac有问题,不解)
google源代码
core
文件夹内为核心代码
其他个文件夹对应Specifying providers and fonts
部分,每个文件夹内组成一个module的概念
google
文件夹内代码为对应从google服务器下载字体css部分
custom
文件夹内代码对应自定义服务方下载
typekit
文件夹内代码对应从typekit处下载
core/cssclassname.js:
主要是对应 WebFont Loader 部分所讲的css class name生成过程,将字体名间的空格,下划线去掉过程:
webfont.CssClassName.prototype.sanitize = function(name) {
return name.replace(/[\W_]+/g, '').toLowerCase();
};
core/cssfontfamilyname.js:
将围绕字体名的',""统一替换为"
core/domhelper.js:
简单的dom操作,添加元素,修改class,为后续生成link以及字体监控元素做准备,注意点在于:
t.appendChild(e) :
// This is safer than appendChild in IE. appendChild causes random
// JS errors in IE. Sometimes errors in other JS exectution, sometimes
// complete 'This page cannot be displayed' errors. For our purposes,
// it's equivalent because we don't need to insert at any specific
// location.
t.insertBefore(e, t.lastChild);
core/eventdispatcher.js:
事件分发机制,将库自身需要进行的操作(对html结点添加删除对应状态class)以及用户自定义的状态回调函数进行统一。
core/font.js
为直接调用部分,实现类WebFont,用户调用load方法传入字体配置后,调用对应module创建link结点,下载css字体文件,并启动检测测试字体变化计时器,根据检测结果调用 eventdispatch 处理变化。
core/fontvariationdescription.js:
对各种缩写配置进行标准化转换。
core/fontwatch.js :
同yui2监视字体大小原理一样,fontwatch一开始就对应每个欲加载字体创建一个结点,并计算元素大小:
<span style="position: absolute; top: -999px; font-size: 300px;
font-family: Tangerine,DEFAULT_FONT; font-style: normal; font-weight: 400;">Mm</span>
其中 Tangerine是我们要加载的字体,设置定时器监控改元素大小,当大小发生变化时立即转移到 font.js 处理。 注意超时设置5秒。
core/initialize.js:
导入库到全局命名空间
core/namespace.js:
只有一个bind工具函数
core/useragent*.js:
浏览器判断,目前只看到对ie script阻塞问题用到了。
google/FontApiParser.js
:更多对字体控制的标准化转换
google/fontapiurlbuilder.js:
根据用户字体配置构造link引用的url地址参数
google/googlefontapi.js:
google module的实现,调用同文件夹其他两个文件,并被 core/font.js调用,主要是再head中增加link元素,开始字体css的下载,注意ie 阻塞问题:
ie等body形成再开始:
if (nonBlockingIe) {
domHelper.whenBodyExists(function() {
domHelper.insertInto('head', domHelper.createCssLink(
fontApiUrlBuilder.build()));
});
} else {
domHelper.insertInto('head', domHelper.createCssLink(
fontApiUrlBuilder.build()));
}
总结:
确实不难的问题,简单来作就是插入测试节点,监控变化,调用回调函数。google仍然坚持了完美的架构,分离分离再分离,最终module,watcher,coreapi,event,variation都可以独立变化
- 大小: 18 KB
分享到:
相关推荐
Nuxt Webfontloader-高效的Web字体加载从未如此简单! 产品特点 完全支持SVG作为组件。 像Vue SFC一样导入它们 建立在Google / Typekit的 通过异步加载Web字体来提高网站性能 Nuxt 2(仅Nuxt 2)支持 经过全面测试...
5. **代码分割**:Nuxt.js 的代码分割特性使得 Webfontloader 只会在需要时才加载,进一步优化了资源请求,减轻了页面负担。 6. **性能优化**:通过预加载字体或者延迟加载,Nuxt Webfontloader 可以帮助你平衡字体...
#Downloading WebFontLoader :第一步是获取 WebFontLoader 代码。 您可以在查看缩小后的代码。 然后,您可以将其复制粘贴到您计算机上的文件中,然后将其链接到您的 index.html 文件中。 您还可以在此 repo 中获取...
Typekit Web 字体加载器Shim 存储库。包管理器 : components-webfontloader : components/webfontloader : components/webfontloader : components-webfontloader
在【压缩包子文件的文件名称列表】中,我们看到"webfontloader-master",这通常意味着包含了Webfont Loader库的源码及其相关文件。在解压后,可能包含以下部分: 1. `webfontloader.js` 或 `webfontloader.min.js`:...
ember-cli-webfontloader WebFontLoader包装在Ember CLI插件中。 允许您通过Ember环境配置文件订阅事件并配置字体。安装ember install ember-cli-webfontloader版本控制考虑到此插件的版本=> 0.4.x需要Ember 2.x,而...
下载网络字体(例如Google字体),并将其托管在WordPress网站本地。 这样可以提高性能(减少对多个顶级域的请求)并提高隐私性。 由于字体是在站点上本地托管的,因此无法ping通到第三方服务器来获取Web字体,因此...
Phaser 3 Webfont加载程序 Phaser 3的Webfont加载器,它使用CSS @font-face...$ npm install -D phaser3-webfont-loader 用法 导入插件 import { WebFontLoaderPlugin } from 'phaser3-webfont-loader' ; 加载插件 ne
用于Typekit的WebFontLoader的ProcessWire模块助手。 DrLunesTypeManager是模板帮助器。 DrLunesTypeManager询问您输入的工具包ID,Google字体系列,CDN,自定义CSS等,并在模板中输出使用此字体所需的代码。 它...
开发工具 fontawesome-webfont.ttf开发工具 fontawesome-webfont.ttf开发工具 fontawesome-webfont.ttf开发工具 fontawesome-webfont.ttf开发工具 fontawesome-webfont.ttf开发工具 fontawesome-webfont.ttf开发工具...
nuxt-font-loader-strategy 帮助加载字体并通过预加载来激活它们。 nuxt-font-loader-strategy帮助加载字体并提供基于预加载的加载策略。 定义自己将首先解锁的字体。 这样可以在网站的初始视口中提供最佳体验。 ...
开发工具 fontawesome-webfont.eot开发工具 fontawesome-webfont.eot开发工具 fontawesome-webfont.eot开发工具 fontawesome-webfont.eot开发工具 fontawesome-webfont.eot开发工具 fontawesome-webfont.eot开发工具...
开发工具 fontawesome-webfont.svg开发工具 fontawesome-webfont.svg开发工具 fontawesome-webfont.svg开发工具 fontawesome-webfont.svg开发工具 fontawesome-webfont.svg开发工具 fontawesome-webfont.svg开发工具...
开发工具 fontawesome-webfont.woff开发工具 fontawesome-webfont.woff开发工具 fontawesome-webfont.woff开发工具 fontawesome-webfont.woff开发工具 fontawesome-webfont.woff开发工具 fontawesome-webfont.woff...
Webfont是一种在网页上使用自定义字体的技术,它允许开发者将特定的字体文件引入到网页中,使得用户在浏览网页时能够看到设计师所选择的独特字体,而无需在本地安装该字体。这种技术对于前端开发来说尤其重要,因为...
WebFont 作为 css3 中比较好的技术被国外广为应用,配合 google webfont loader 方案能很好的实现页面字体动态加载,并且脱离了终端字体库的限制。 WebFont 纵然很好,但是目前没有较好的中文解决方案。一是 google ...
fontgen-loader, 从SVG图标自动生成 webfont web service使用 ! fontgen-loader - Bam,轻松 webfonts !你遇到了这个你有 4个图标,从FontAwesome到 19,也许你是eying的另一个图标,希望使用它们?真是一团糟行了...
从压缩包文件名称 "webfont-opensans-master" 可以推测,这是项目的一个主分支或者源代码版本,可能包含了 OpenSans 的完整字体集以及相关的 CSS 文件和其他配置文件。 总结来说,"webfont-opensans: Google ...
在前端开发领域,为了实现美观且可自定义的字体图标,开发者经常使用WebFont技术。WebFont允许将矢量图形(如SVG)转换为可在网页上使用的字体文件,从而实现跨浏览器、响应式的设计。"grunt-webfont"是这样一个开源...
fontawesome-webfont.eot