百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 文章教程 > 正文

如何将20M+的字体压缩到几KB:前端性能优化的极致探索

yund56 2025-04-25 17:21 7 浏览

在前端开发中,字体文件的加载速度往往直接影响到用户体验。当字体文件过大时,页面渲染速度会显著变慢,导致用户等待时间过长。最近,在开发海报编辑器时,意外发现字体文件过大导致加载缓慢的问题。今天,我们将一起探讨如何通过技术手段将20M+的字体文件压缩到几KB,从而显著提升页面加载速度。

一、问题背景:字体文件为何如此之大?

在开发海报编辑器时,发现某些字体文件过大,导致页面加载缓慢。具体来说,一张海报中包含6种字体,其中最大的字体文件超过20M,最长的网络加载时间接近20秒。这严重影响了用户体验。那么,为什么字体文件会这么大呢?

1.中文字符数量庞大

中文字符数量远多于英文。英文只有26个字母加上一些符号,而中文(全字符集)包含70,000+字符。这意味着字体文件需要为每个字符存储独立的矢量轮廓数据,而汉字笔画复杂,每个字符需要存储数百个控制点坐标。

2.字形结构复杂

汉字的笔画复杂,每个字符需要存储更多的控制点坐标。例如,“龍”字的轮廓点数量可能是“a”的10倍以上。这使得字体文件的体积显著增加。

二、常见的字体格式及优化方向

常见的Web字体格式包括TTF、WOFF和WOFF2。其中,WOFF2格式在TTF/OTF基础上添加了压缩和Web专用元数据,支持增量解码,可以显著减少文件体积。

1.TTF文件

TTF文件体积较大,例如思源黑体的TTF文件为16.9MB。

2.WOFF2文件

WOFF2文件通过压缩和Web专用元数据,可以显著减少文件体积。例如,思源黑体的WOFF2文件为7.4MB,压缩率约为60%。

三、优化方案:字体子集化与按需加载

为了优化字体加载速度,我们可以采用以下两种主要方案:字体子集化和按需加载。

1.字体子集化

字体子集化是指通过工具将字体文件进行提取,返回指定字符集的字体文件。其核心是减少单次资源请求的体积。这种方法适用于所有优化场景,尤其是动态子集化方案,可以显著减少字体文件的体积。

实现动态子集化

使用了Python的fontTools库来实现动态子集化。以下是实现代码的示例:

from flask import Flask, request, Response
from io import BytesIO
from fontTools.ttLib import TTFont
from fontTools.subset import Options, Subsetter

app = Flask(__name__)

@app.route('/font/<font_name>', methods=['GET'])
def get_font_subset(font_name):
    font_path = f'fonts/{font_name}.ttf'
    chars = request.args.get('text', '')
    format = request.args.get('format', 'woff2').lower()

    unique_chars = ''.join(sorted(set(chars)))

    try:
        options = Options()
        options.flavor = format if format in {'woff', 'woff2'} else None
        options.desubroutinize = True

        subsetter = Subsetter(options=options)
        font = TTFont(font_path)
        subsetter.populate(text=unique_chars)
        subsetter.subset(font)

        buffer = BytesIO()
        font.save(buffer)
        buffer.seek(0)

        mime_type = {
            'woff2': 'font/woff2',
            'woff': 'font/woff',
        }[format]

        response = Response(buffer.read(), mimetype=mime_type)
        return response

    except Exception as e:
        print(f"Error: {e}")
        return "Error", 500

if __name__ == '__main__':
    app.run(debug=True)

2.按需加载

按需加载是指通过设置unicode-range属性,浏览器在进行CSS样式计算时,会根据页面中的字符与设置的字符范围进行比对,匹配上会加载对应的字体文件。这种方法适用于多语言切换的场景。

四、前端代码实现

在前端代码中,通过FontFace API动态加载字体资源。以下是前端代码的示例:

Toast.loading('字体加载中');
const fontFamilies = new Set(['字体1', '字体2', '字体3']);
const textMap = {
    '字体1': ['文案1', '文案2'],
    '字体2': ['文案3', '文案4'],
    '字体3': ['文案5', '文案6']
};

[...fontFamilies].forEach((fontName) => {
    const obj = fontLibrary.find((el) => el?.value === fontName) ?? {};
    if (obj.value && obj.src) {
        const text = textMap[obj.value].join('');
        const font = new FontFace(
            obj.value,
            `url(http://127.0.0.1:5000/font/${obj.value}?text=${text}&format=woff2)`
        );
        font.load();
        document.fonts.add(font);
    }
});

document.fonts.ready.finally(() => Toast.destroy());

五、优化效果

通过动态子集化,将实际22.4M的字体文件压缩到了3.6KB,实际效果图生成的时间从20秒以上缩减到了300毫秒以内。这显著提升了页面加载速度,改善了用户体验。

优化字体加载的方案有很多,但字体子集化和按需加载是两种非常高效且实用的手段。通过动态子集化,我们可以显著减少字体文件的体积,从而提升页面加载速度。如果你的项目中也面临字体文件过大的问题,不妨尝试一下这些优化方案。更多实践思路可以参考Google Fonts。

相关推荐

七夕前学起来,程序员的浪漫:三十行代码实现用她的名字作幅画

hello,各位小伙伴们大家早上|中文|晚上|凌晨好,相信看这篇文章的有很多新朋友,估计也有少量的老朋友,首先做个简短的自我介绍,我是一灰灰,码农界的资深搬运工;今天呢,没有站在我身边的捧哏老师,那就...

127.手摇计算机的收藏(我的民间收藏笔记)

1970年代前后,我国生产的手摇计算机,主要有上海飞鱼牌和通用牌手摇计算机,天津文化牌手摇计算机。这几种手摇计算机的收藏价,目前很不统一。品相好又能使用的收藏价大概为1500—7000元。品相不好又...

计算机毕业设计Hadoop+Hive+PySpark小说推荐系统 小说可视化

基于Spark+hadoop大数据小说数据分析推荐系统(完整系统源码+数据库+开发笔记+详细部署教程+虚拟机分布式启动教程)直拍源码包部署爬虫可用基于用户协同过滤算法开发技术介绍编辑器:Pychar...

win7系统exe病毒文件夹怎么删除

Win7系统中exe病毒文件夹如何删除?下面为大家提供解决办法,快来了解吧!1、按下Win+R快捷键,输入gpedit.msc,所示,即可打开组策略编辑器。2、依次展开计算机配置下的管理模板,进入...

Windows 10 网络搜索设计太反人类?教你如何彻底关闭它

来源:太平洋电脑网我们知道微软在Windows10中,特别加强了系统的搜索功能,但Windows10的搜索的确很难称得上好用。抛开效率低下、呈现结果少、造成系统卡顿等老生常谈的问题不论,在功能设计...

win7系统exe病毒文件夹怎么删除?

经常遇到病毒文件夹,它们通常是带有exe后缀的文件夹名称,双击后会复制病毒。今天就教大家如何删除这些病毒文件夹。1、打开开始菜单,点击运行按钮;或者按下Win+R键,即可开启运行对话框。2、运行窗...

通过代码编写电脑关机程序

大家好,我是Anyday这期给大家分享的电脑小知识是通过代码编写程序进行关机。首先在桌面右键新建一个文本文档双击打开新建文档,在里面输入shutdown–s–t0,这就是我们上一期的关机代码(聪...

可视化程序设计必备书:从零开始Qt可视化程序设计

“可视化程序设计”是理工科极为重要的一门专业课程,实践性很强。其教学目标是使学生掌握可视化程序设计的基本方法、编程技能并具备上机调试能力,熟悉界面设计,掌握各种常用类(有些开发工具称控件,实...

重要通知!25年公务员专业参考目录已出!

大家关心的2025年江苏省公务员考试消息有了!一年一度江苏省公开征求对《江苏省2025年度考试录用公务员专业参考目录》的意见和建议公告出了!各地的公务员专业参考目录其实都查不多,江苏针对今年的具体情况...

计算机二级考试中的一些注意事项

科教武汉【计算机二级考试中的一些注意事项】1、要合理安排做题时间可以先通过观察整个题目的题形,判断整个试卷的难点,通过观察题型然后确定自己的应对策。选择题建议用时15-20分钟为好。自己要有一个时间...

天津专升本计算机知识点 选定文件和文件夹

在Windows7系统中,进行选定,包括多种,考试重点内容有三种。①选定多个连续的文件或文件夹,可用Shift键配合鼠标进行选定②选定多个不连续的文件或文件夹,可用Ctrl键配合鼠标进行选定③撤销某...

最新发布!四川这些岗位急需紧缺人才

12月17日,《四川省人力资源服务业急需紧缺人才目录》发布。据介绍,《四川省人力资源服务业急需紧缺人才目录》采集600余家用人单位信息,调查整理了40余家用人单位需求,从收集的上千条岗位信息中分析出3...

最新!普通高等学校本科专业目录(2024年)!共816种本科专业

高考成绩已定,目前最重要的,就是填报高考志愿了!!!(点击查看:广西2024高考分数线、一分一档表公布!今天开始填志愿!附前3年高考分数线、一分一档表)除了要在1308所本科大学中选出自己(孩子)喜欢...

cad文件夹加密

我学计算机辅助设计,常用CAD绘制图纸并存入文件夹。有时担心关机后设计被窃,便在网上寻找解决办法,最终找到了一种加密CAD文件夹的实用方法,有效保护了我的设计成果。1、首先,我们需要安装一款保护文件...

文件夹加密大师使用方法:快速加密文件指南

不想让他人看到私密文件?以下几种隐藏文件的方法各有优缺点,快来看看哪种最适合你!1、隐藏的文件夹2、首先,右击文件夹选择属性,在常规选项卡勾选隐藏,然后点击确定。3、若文件夹为隐藏状态,打开我的...