写点什么

加载时间从 4.6s 降到 0.7s,谷歌开源 quicklink

  • 2019-01-25
  • 本文字数:2649 字

    阅读完需:约 9 分钟

加载时间从4.6s降到0.7s,谷歌开源quicklink

近日,Google 团队在 GitHub 上开源了一个项目 quicklink,quicklink 能在空闲时预取 viewport 内的链接来加快后续页面的加载速度。具体的技术原理和实现过程请看下文。

工作原理

quicklink 通过以下措施加快后续页面的加载速度:


  • 检测 viewport 中的链接,使用Intersection Observer

  • 等待浏览器空闲,使用requestIdleCallback

  • 检查用户的连接速度(使用 navigator.connection.effectiveType)或者是否启用了 data-saver(使用 navigator.connection.saveData);

  • 预取链接(使用或 XHR),可以控制请求优先级(如果支持,可以切换到 fetch())。

为什么要推出 quicklink?

quicklink 旨在成为根据用户 viewport 中的链接预取内容的简易解决方案,而且要保持很小的体积(压缩后小于 1KB)。

安装

npm install --save quicklink
复制代码


也可以从unpkg.com/quicklink下载 quicklink。

用法

在初始化后,quicklink 将自动在空闲时预取 viewport 内的链接。


<!-- Include quicklink from dist --><script src="dist/quicklink.umd.js"></script><!-- Initialize (you can do this whenever you want) --><script>quicklink();</script>
复制代码


例如,你可以在 load 事件触发后进行初始化:


<script>window.addEventListener('load', () =>{   quicklink();});</script>
复制代码


ES 模块导入:


import quicklink from "quicklink/dist/quicklink.mjs";quicklink();
复制代码


上面的选项最适合多页面网站。单页应用程序也有几个可用的选项:


  • 在完成新路由导航后调用 quicklink();

  • 针对特定的 DOM 元素/组件调用 quicklink();

  • 使用自定义 URL 调用 quicklink({urls:[…]})进行预取。

API

quicklink 可以接受带有以下参数的可选选项对象:


  • el:包含需要预取的链接的 DOM 元素;

  • urls:要预取的 URL 数组(不是在 viewport 中检测到的文档或 DOM 元素的链接);

  • timeout:requestIdleCallback 超时时间,浏览器执行预取的时间(以毫秒为单位),默认为 2 秒;

  • timeoutFn:用于指定超时的函数,默认为 requestIdleCallback,也可以替换为networkIdleCallback等自定义函数;

  • priority:布尔值,指定预取优先级,默认为 false。如果设置为 true,将尝试使用 fetch() API(而不是 rel=prefetch);

  • origins:允许预取的 URL 主机名字符串数组。默认为与域名相同的 origin,防止跨 origin 请求;

  • ignores:一个 RegExp 函数或数组,用于决定是否应该预取某个 URL。在 orign 匹配之后执行。


待完成事项:


  • 检测资源的文件扩展名,并使用 rel=preload 进行高优先级预取;

  • 使用Priority Hints进行重要性提示。

polyfill

quicklink:


  • 可以回退到 requestIdleCallback;

  • 需要支持 IntersectionObserver,请参阅CanIUse。我们建议使用 Polyfill.io 等服务来有条件地 polyfill 该功能:


<script src="https://polyfill.io/v2/polyfill.min.js?features=IntersectionObserver"></script>
复制代码

一些示例

设置自定义的资源预取超时时间

默认为 2 秒(通过 requestIdleCallback),在这里我们将其设置为 4 秒:


quicklink({  timeout: 4000});
复制代码

设置包含预取 URL 的 DOM 元素

如果不设置,默认为 document。


const elem = document.getElementById('carousel');quicklink({  el: elem});
复制代码

设置预取 URL 数组

如果你想要直接提供预取 URL 的列表,而不是去检测 viewport,可以使用 URL 数组。


quicklink({   urls: ['2.html','3.html', '4.js']});
复制代码

设置预取的请求优先级

默认为低优先级(rel=prefetch 或 XHR)。对于高优先级(priority: true),尝试使用 fetch(),或者回退到 XHR。


quicklink({ priority: true });
复制代码

指定 origin 自定义列表

提供可预取的主机名列表。默认情况下只允许来自相同 origin 的 URL。


quicklink({  origins: [    // add mine    'my-website.com',    'api.my-website.com',    // add third-parties    'other-website.com',    'example.com',    // ...  ]});
复制代码

允许所有 origin

启用所有跨 origin 请求。


quicklink({  origins: true,  // or  origins: []});
复制代码

自定义 Ignore 模式

这些过滤器在 origin 匹配之后运行,对于避免下载大文件或动态响应 DOM 属性来说非常有用。


// Same-origin restraint is enabled by default.//// This example will ignore all requests to://  - all "/api/*" pathnames//  - all ".zip" extensions//  - all <a> tags with "noprefetch" attribute//quicklink({  ignores: [    /\/api\/?/,    uri => uri.includes('.zip'),    (uri, elem) => elem.hasAttribute('noprefetch')  ]});
复制代码


你可能希望忽略包含 URL 片段的 URL(例如 index.html #top)。如果你在页面中使用了锚点或为单页面应用程序设置了 URL 片段,希望避免触发此类 URL 的预取, 那么这项功能非常有用。


quicklink({    ignores: [        uri => uri.includes('#')        // or RegExp: /#(.+)/        // or element matching: (uri, elem) => !!elem.hash    ]});
复制代码

浏览器支持

quicklink 提供的预取可以被视为一种渐进式增强。跨浏览器支持情况如下:


  • 没有 polyfill:Chrome、Firefox、Edge、Opera、Android Browser, Samsung Internet。

  • 使用 Intersection Observer polyfill:Safari、IE11。

  • 上面的再加上 Set()和 Array.from polyfill:IE9 和 IE10。Core.js提供了 Set()和 Array.from()填充,也可以考虑es6-shim


提供了某些功能的分层支持:


  • Network Information API,用于检查用户的连接类型(通过 navigator.connection.effectiveType),仅适用于 Chrome 61+和 Opera 57+。

  • 如果选择{priority: true}并且 Fetch API 不可用,则将使用 XHR。

直接使用 prefetcher

quicklink 包含一个 prefetcher,可以单独导入到其他项目中使用。在将 quicklink 作为依赖项安装好以后,可以按如下方式使用它:


<script type="module">import prefetch from '../src/prefetch.mjs';
const urls = ['1.html', '2.html'];const promises = urls.map(url => prefetch(url));Promise.all(promises);</script>
复制代码

演示

这里是一个 WebPageTest演示


通过使用 quicklink,将页面加载时间减少了 4 秒。这里是进行预取前后的比较视频


出于演示的目的,我们在 Firebase 上部署了一个谷歌博客,然后我们又部署了另一个版本,在主页上添加了 quicklink,并测试从主页导航到文章的速度,结果预取版本的加载速度更快。


请注意:这并不是一个针对 viewport 内链接预取优缺点的详尽基准测试,我们只是演示了这个方法可以为我们带来的潜在改进。


英文原文:https://github.com/GoogleChromeLabs/quicklink


更多内容,请关注前端之巅。



2019-01-25 07:0017994
用户头像

发布了 731 篇内容, 共 462.4 次阅读, 收获喜欢 2005 次。

关注

评论 1 条评论

发布
用户头像
这个好
2019-01-27 10:48
回复
没有更多了
发现更多内容

BeeWorks内网聊天软件:提升团队效率的智能沟通平台

BeeWorks

即时通讯 IM 企业即时通讯平台 私有化部署 局域网视频软件

SonarQube Server 2025 Release 2 发布 - 代码质量、安全与静态分析工具

sysin

SonarQube

HarmonyOS NEXT 中级开发环境搭建与实用工具类 AI 问答 APP 开发

yimapingchuan

HarmonyOS NEXT

AI应用如何从 Chat 进化为 Agent?开源项目源码深度揭秘|得物技术

得物技术

agent 大模型应用

如何开发RWA DApp?一文搞定——从资产确权到跨链流通的完整技术指南

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 代币开发

周卫林|从模型平权到“知本”复利,NoETL 打造 AI 时代的数据底座

Aloudata

数据仓库 数据分析 数据管理 大模型 指标平台

项目过程中会出现哪些问题?

秃头小帅oi

AI低代码MES:制造业从“制造”到“智造”

万界星空科技

AI 低代码开发 低代码平台 mes 低代码云MES

模型的泛化性能度量:方法、比较与实现

秃头小帅oi

5000万考生救星!百度网盘和文库首发一站式视频AI笔记

极客天地

一文读懂2024!2025往“这”瞧 |《2024 IT行业项目管理调查报告》发布!

禅道项目管理

项目管理 AI IT 调查报告 科技

2025浙江安博会

AIOTE智博会

安博会 浙江安博会 杭州安博会

必看!SpringAI轻松构建MCP Client-Server架构

王磊

DeepSeek 3FS 架构分析和思考(下篇)

火山引擎开发者社区

火山引擎智能数据洞察 ChatBI 适配 DeepSeek-R1 及 DeepSeek-V3

火山引擎开发者社区

当AI遇上低代码:程序员正在咖啡馆里泡手冲?

伤感汤姆布利柏

华为吴辉:跨越数智鸿沟,共创AI新时代

新消费日报

智能制造:自动化焊装线的数字化设计

积木链小链

数字化 制造业 智能制造

币安再度封禁违规做市商,Crypto 行业还有多少「蛀虫」

TechubNews

比特币

DeepSeek Smallpond 在火山引擎 AI 数据湖的探索实践

火山引擎开发者社区

Web3项目的分类及特点

北京木奇移动技术有限公司

区块链技术 软件外包公司 web3开发

国产服务器操作系统CTyunOS,技能值拉满!

天翼云开发者社区

云计算 服务器操作系统

哈姆hahm是什么样的平台,模式是什么样的

web3区块链创业团队DappNetWork

Web3项目的安全性

北京木奇移动技术有限公司

区块链技术 软件外包公司 web3开发

哈姆hahm是个什么项目?HAHM点评能长久做吗?

web3区块链创业团队DappNetWork

行业分享丨如何实现快速仿真和创新设计,颠覆式加速产品研发?

Altair RapidMiner

AI 数字化转型 HPC 仿真 仿真驱动设计

RabbitMQ集群部署(一)——单机模式部署

天翼云开发者社区

RabbitMQ

DApp开发中的三大激励引擎:静态奖、动态奖与推荐奖的协同设计 ——从经济模型到行为心理学的深度解析

区块链软件开发推广运营

交易所开发 dapp开发 链游开发 公链开发 代币开发

爱橙科技基于 MaxCompute 智能物化视图最佳实践

阿里云大数据AI技术

大数据 阿里云 SaaS MaxCompute 物化视图

Hologres诊断与优化快速入门

阿里云大数据AI技术

数据库 sql 大数据 阿里云 hologres

测试框架设计的艺术

FunTester

加载时间从4.6s降到0.7s,谷歌开源quicklink_大前端_Geek_q4vipd_InfoQ精选文章