预获取
页面加载时间在网站的可用性和整体体验中扮演着重要角色。当你的访问者与网站进行交互时,Astro 的可选预获取功能能在你的多页面应用(MPA)中带来几乎瞬时的页面导航的好处。
启用预获取
段落标题 启用预获取你可以使用 prefetch
配置来启用预获取:
一个预获取脚本将被添加到你网站的所有页面。然后你可以在你网站的任何 <a />
链接上添加 data-astro-prefetch
属性来选择预获取。当你将鼠标悬停在链接上时,脚本将在后台获取页面。
注意,预获取只适用于你的网站内的链接,不适用于外部链接。
预获取配置
段落标题 预获取配置prefetch
配置也接受一个选项对象,以进一步自定义预获取。
预获取策略
段落标题 预获取策略Astro 支持 3 种预获取策略,以适应各种用例:
hover
(默认):当你将鼠标悬停在链接上或聚焦在链接上时预获取。tap
:在你点击链接之前预获取。viewport
:当链接进入视口时预获取。
你可以通过将其传递给 data-astro-prefetch
属性来为单个链接指定策略:
每种策略都经过了微调,只有在需要时才预获取,以节省用户的带宽。例如:
默认预获取策略
段落标题 默认预获取策略添加 data-astro-prefetch
属性时的默认预获取策略是 hover
。要更改它,你可以在你的 astro.config.js
文件中配置 prefetch.defaultStrategy
:
默认预获取所有链接
段落标题 默认预获取所有链接如果你想预获取所有链接,包括那些没有 data-astro-prefetch
属性的链接,你可以将 prefetch.prefetchAll
设置为 true
:
然后你可以通过设置 data-astro-prefetch="false"
来为单个链接选择不进行预获取:
所有链接的默认预获取策略可以通过 prefetch.defaultStrategy
更改,如 默认预获取策略部分 所示。
可编程的预获取
段落标题 可编程的预获取由于一些导航可能不总是以 <a />
链接的形式出现,你也可以使用 astro:prefetch
模块中的 prefetch()
API 进行程序化预获取:
你还可以通过传递 with
选项来配置预获取的优先级:
prefetch()
API 包括相同的流量节省模式和慢速连接检测,因此只有在需要时才预获取。
确保只在客户端脚本中导入 prefetch()
,因为它依赖于浏览器 API。
与视图过渡动画一起使用
段落标题 与视图过渡动画一起使用当你在页面上使用 视图过渡动画 时,预获取也将默认启用。它设置了一个默认配置 { prefetchAll: true }
,在页面上启用 所有链接的预获取。
你可以在 astro.config.js
中自定义预获取配置以覆盖默认设置。例如:
从 @astrojs/prefetch
迁移
段落标题 从 @astrojs/prefetch 迁移@astrojs/prefetch
集成在 v3.5.0 中被弃用,最终将被完全移除。使用以下说明将 @astrojs/prefetch
迁移到 Astro 的内置预获取,这将替代这个集成。
-
删除
@astrojs/prefetch
集成,并在astro.config.js
中启用prefetch
配置: -
从
@astrojs/prefetch
的配置选项转换:-
已弃用的集成使用
selector
配置选项来指定哪些链接应在进入视口时被预获取。而现在,你需要在这些单独的链接上添加
data-astro-prefetch="viewport"
。 -
已弃用的集成使用
intentSelector
配置选项来指定哪些链接在被悬停或聚焦时应被预获取。现在,你需要在这些单独的链接上添加
data-astro-prefetch
或data-astro-prefetch="hover"
: -
@astrojs/prefetch
的throttles
选项不再需要,因为新的预获取特性将自动调度和优化预获取。
-