`
yiminghe
  • 浏览: 1475282 次
  • 性别: Icon_minigender_1
  • 来自: 上海
社区版块
存档分类
最新评论

google WebFont Loader 源码阅读

阅读更多

资料:


关于新发布的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
分享到:
评论

相关推荐

    前端项目-webfont.zip

    在【压缩包子文件的文件名称列表】中,我们看到"webfontloader-master",这通常意味着包含了Webfont Loader库的源码及其相关文件。在解压后,可能包含以下部分: 1. `webfontloader.js` 或 `webfontloader.min.js`:...

    前端开源库-webfont-dl

    在压缩包文件"webfont-dl-master"中,包含了Webfont-dl库的源代码,你可以查看其结构和实现细节,了解其工作原理,甚至根据项目需求进行二次开发。同时,通过阅读文档或示例,你可以更轻松地将Webfont-dl集成到你的...

    canvas使用外部字体

    &lt;script src="https://ajax.googleapis.com/ajax/libs/webfont/1.6.26/webfont.js"&gt;&lt;/script&gt; WebFont.load({ custom: { families: ['Inconsolata'], urls: ['Inconsolata.ttf'] }, active: function() { ...

    DeepSeek入门宝典:赋能开发者实战的高性能AI解决方案

    内容概要:本文档详细介绍了 DeepSeek 这一高效、经济的人工智能解决方案,旨在为企业端、产品端以及开发者提供深度技术支持。对于企业而言,DeepSeek 带来了显著的成本效益和生产效率提升;而对于具体的产品和服务,它增强了用户体验的质量。特别是针对开发者,文档深入浅出地讲解了如何利用 DeepSeek 实现自动化代码生成、改写等辅助开发功能,并且提供了具体的步骤指导以满足不同环境下的部署需求,包括直接通过官方API接入、本地私有化部署或借助云平台进行托管的方式。 适合人群:希望降低开发门槛,提高工作效率的软件工程师和技术团队。 使用场景及目标:开发者可以根据自身条件选择最适合自己的部署方案来整合 DeepSeek 技术,进而达到优化编码过程、减少人为错误的目的。 其他说明:文中还包括了许多实际操作的例子,如通过代码改写的实例来展示如何改进现有程序段落,还有详细的API使用指南帮助初学者快速上手DeepSeek。此外,还提供了大量外部参考资料链接以便进一步扩展知识和技能范围。

    lusted_3cd_01_0318.pdf

    lusted_3cd_01_0318

    开源AI工具下载——Cherry-Studio-1.0.1-MACOS arm64版

    Cherry Studio是一款支持多模型服务的 Windows/macOS GPT 客户端。通过与Ollama搭配,搭建个人本地AI大模型

    chromedriver-win64-136.0.7058.0.zip

    chromedriver-win64-136.0.7058.0.zip

    matlab程序代码项目案例:使用 Simulink 进行自适应 MPC 设计

    matlab程序代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    mellitz_3cd_01_1116.pdf

    mellitz_3cd_01_1116

    基于MATLAB的牛顿迭代法实现

    基于MATLAB的牛顿迭代法实现

    steenman_01_0908.pdf

    steenman_01_0908

    [AB PLC例程源码][MMS_047737]System Time 64Bit Interpreted AOI.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    stone_3ck_01a_0518.pdf

    stone_3ck_01a_0518

    [AB PLC例程源码][MMS_041473]Input Time Stamping.zip

    AB PLC例程代码项目案例 【备注】 1、该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的,请放心下载使用!有问题请及时沟通交流。 2、适用人群:计算机相关专业(如计科、信息安全、数据科学与大数据技术、人工智能、通信、物联网、自动化、电子信息等)在校学生、专业老师或者企业员工下载使用。 3、用途:项目具有较高的学习借鉴价值,不仅适用于小白学习入门进阶。也可作为毕设项目、课程设计、大作业、初期项目立项演示等。 4、如果基础还行,或热爱钻研,亦可在此项目代码基础上进行修改添加,实现其他不同功能。 欢迎下载!欢迎交流学习!不清楚的可以私信问我!

    lusted_3cd_01_1117.pdf

    lusted_3cd_01_1117

    2010-2023年 上市公司-管理层情感语调数据.zip

    管理层情感语调,或称为管理层语调,是一个在财务与会计领域中常用的概念,特别是在分析上市公司信息披露质量时。它主要指的是管理层在上市公司文字信息披露过程中,用词所体现出的情感倾向和可理解性。 本数据复刻了《财经研究》《中南财经政法大学学报》等顶级期刊的核心解释变量的做法。情感语调对企业未来盈余和未来绩效具有较强解释力、降低会计信息误定价、为分析师预测提供增量信息,而投资者也会对管理层情感语调做出积极反应。 情感语调1=(正面词汇数量-负面词汇数量)/词汇总量;数值越大,情感倾向越偏向正面积极。 情感语调2=(正面词汇数量-负面词汇数量)/(正面词汇数量+负面词汇数量);数值越大,情感倾向越偏向正面积极。 指标 证券代码、企业代码、年份、证券简称、行业代码、行业名称、正面词汇数量、负面词汇数量、词汇总量、句子数量、文字数量、情感语调1、情感语调2。

    mellitz_3cd_02_0318.pdf

    mellitz_3cd_02_0318

    moore_01_0909.pdf

    moore_01_0909

    lusted_3ck_02a_0119.pdf

    lusted_3ck_02a_0119

    pimpinella_3cd_01_0916.pdf

    pimpinella_3cd_01_0916

Global site tag (gtag.js) - Google Analytics