如今的网页上充斥着图像、视频和其他有趣的内容,有时会导致加载缓慢。
想要让您的网页更快吗?尝试在用户打开网页之前对其进行预渲染或预取。这样,您的内容就可以随时使用,为访问者提供无缝且快速的浏览体验。Speculative Loading API 解决了以前未解决的问题。过去,解决方案侧重于预取 JavaScript 和 CSS 等资源,但不涉及预渲染整个网页。
2024 年初,谷歌的 Adam Silverstein 提到 WordPress Performance 团队正在开发一个插件来启用 Speculation Rules API。
2024年4月,WordPress官方发布了支持Speculation Rules API的性能插件Speculative Loading。
推测规则 API 允许开发人员定义预渲染和预取内容规则。
通过在用户导航到页面或资源之前在后台加载页面或资源,这有助于缩短页面加载时间。
API 控制哪些页面应该预渲染以及在什么条件下预渲染,从而实现更高效的资源利用和更流畅的用户体验。
1. 预取指示浏览器下载引用页面的主要内容而不获取其子资源。这可加快用户导航到预取页面时的加载时间。
标签: <link rel=”prefetch”…>
2. 预渲染更进一步,指示浏览器获取、渲染和加载所有内容(包括子资源和 JavaScript)到一个不可见的选项卡中,当用户进入该选项卡时,该选项卡将在大约 50 毫秒内加载。
标签: <link rel=”prerender”…>
服务器资源 | 推测加载可能会增加资源使用率,特别是对于共享托管服务器上的站点。 建议根据可用的站点/服务器资源配置插件,以防止可扩展性问题。 |
PHP 版本 | Speculative Loading 插件要求 PHP 最低版本为 7.2 或更高版本。 |
WordPress 版本 | 该插件要求 WordPress 版本最低为 6.4,其功能已测试至 6.53 版本。 |
插件安装 | Speculative Loading 插件有超过 10,000 个活跃安装。 |
推测规则可以添加在主机的头部或者主体中。
您可以通过两种格式添加推测加载 API:
1. 静态设置,您可以在此处添加静态页面 URL。这对于下一步操作非常可预测的网站非常有效。
2.使用 JavaScript 进行动态设置。这适用于大量使用个性化用户体验的网站。
让开发人员和网站所有者更具体地了解应该预渲染哪些 URL。
当您安装插件时,它会自动以中等程度的预渲染设置预渲染链接页面。当您将鼠标悬停在链接上时,就会发生这种情况。因此,激活插件后,您无需执行任何操作;它会自动运行。
如果需要,您可以更改“设置”>“阅读”下的“推测加载”部分。
例如,如果您在 WordPress 网站上安装了 Speculative Loading 插件,则可以使用 Chrome DevTools检查该网站。
点击元素选项卡,向下滚动,您会看到已经添加的script type=”speculationrules” ,其中包含各种推测规则。
<script type="speculationrules"> { “预渲染”:[ { “来源”:“列表”, “urls”:[“shop”,“test”] } ] } </script>
预取也是如此,它通常是预渲染之前的一个很好的起点:
<script type="speculationrules"> { "预取":[ { “urls”:[“示例页面”,“test1”] } ] } </script>
<script type="speculationrules"> { “预渲染”:[ { “来源”:“文件”, “在哪里”: { “和”: [ { “href_matches”:“/*” }, { “不是”: { "href_matches": [ “/wp-login.php” “/wp-admin/*” ] } } ] }, “渴望程度”:“中等” } ] } </script>
在上面的代码片段中,页面上的所有 URL 都已准备好进行预渲染,但转到 WordPress 登录和管理页面的 URL 除外。您还可以设置预渲染的程度。
当您使用推测规则 API 时,您可以在检查页面时使用 Chrome应用程序选项卡中推测加载的后台服务进行检查。
重要笔记:
立即和急切设置不依赖于用户操作,因此它们具有更高的限制。它们可以通过删除较旧的预渲染页面来动态调整容量。
对于中等和保守的设置,您最多可以预渲染 2 个页面。这些页面由用户操作触发,并遵循先进先出 (FIFO) 规则。如果您预渲染第三个页面,它将替换第一个页面以节省内存。
热切 | 预取 | 预渲染 |
立即/渴望 | 50 | 10 |
温和/保守 | 2 (先进先出) | 2 (先进先出) |
值得注意的是,WP-admin路由默认会自动排除在预渲染和预取之外。
您可以使用plsr_speculation_rules_href_exclude_paths过滤器推测性地设置要预加载的 URL 类型的规则。
以下代码示例可确保 https://wordpresssite.com/cart/ 或 https://wordpresssite.com/cart/checkout/ 等 URL 被排除在预取和预渲染之外:
?php 添加过滤器( 'plsr_speculation_rules_href_exclude_paths', 函数($exclude_paths){ $exclude_paths[] = '/购物车/*'; 返回 $exclude_paths; } (英文):
如果您看到一条错误消息,提示“推测规则 API 已被禁用”,请按照以下步骤在浏览器设置中启用它。
启用推测规则 API 取决于浏览器支持情况和特定设置或标志。目前,并非所有浏览器都默认支持此功能,在某些情况下它可能仍处于实验阶段。
跨站预取有限制,以保护用户隐私。只有当用户未针对目标网站设置 Cookie 时,它才会起作用,这有助于避免跟踪用户活动。
更好的页面加载时间、增强的用户满意度和潜在的 SEO 优势使这项技术成为开发人员的绝佳选择。
通过减少页面切换之间的延迟,用户会感觉网站更流畅、响应更快。您可以在网站的核心 Web 指标中看到这种改进,其中最大内容绘制 (LCP)、累积布局偏移 (CLS) 和下一次绘制交互 (INP) 等指标显着下降。
即时浏览可降低跳出率并提高用户留存率,这对您网站的成功至关重要。这凸显了整合 Speculation Rules API 的战略重要性。
新的Speculative Loading是开源软件,在WordPress中,它的运行方式与WP Rocket不同。
WP Rocket 是一款高级缓存插件,可通过各种优化(如缓存、最小化和延迟加载)来提高网站速度。
推测加载可以预测用户操作来预取和预渲染内容,通过准备用户将访问的下一个页面来减少加载时间。
相比之下,WP Rocket 提供了链接预加载功能,该功能使用 JavaScript 在鼠标悬停时预加载链接。
推测加载 API 允许开发人员为浏览器设置规则,以根据对用户接下来可能点击的内容的预测来预取或预渲染链接的 URL。
分析对于跟踪网站使用情况(包括页面浏览量和事件)以及通过真实用户监控 (RUM) 评估性能至关重要。了解预渲染会影响分析至关重要。
例如,如果您使用的是 Google Analytics,则无需采取额外措施,因为 GA 默认会延迟预渲染直至激活。但是,使用其他分析工具时,预渲染页面可能会影响数据收集。
网站所有者可能需要添加额外的代码来确保分析仅在查看页面时激活。这可以使用Promise来实现,即使文档正在预渲染,它也会等待预渲染更改。
虽然 Google Analytics、Google Publisher Tag (GPT) 和 Google AdSense 会延迟跟踪直至页面处于活动状态,但并非所有提供商都会自动执行此操作。
为了解决这个问题,你可以设置一个 Promise,仅在页面激活时开始分析:
const whenActivated = new Promise((resolve) => { 如果(document.prerendering){ document.addEventListener('prerenderingchange',resolve); } 别的 { 解决(); } }); 异步函数 initAnalytics() { 等待激活时; // 初始化分析 } 初始化分析();
推测性加载可通过预测用户行为并在后台预加载内容来提高 WordPress 网站的页面速度。这可缩短加载时间,为访问者带来更流畅、更高效的浏览体验。
不,推测加载插件不使用人工智能 (AI)。相反,它使用 Google 的推测规则 API,将 JSON 脚本插入页面上链接的任何 URL,并使用“中等”热切配置对其进行预渲染。
推测加载策略可应用于所有页面,但用户操作不会对其进行修改。一个好的经验法则是避免预渲染或预提取结帐和购物车页面,因为这可能会导致糟糕的用户体验。此外,Google 建议仅在用户加载页面的可能性较高(大于 80%)时才预渲染页面。
推测规则 API 支持定义URL 模式,以指定哪些 URL 应该有资格进行推测加载。