Die beste Möglichkeit, Routendaten vorab zu laden, bevor auf die Route zugegriffen wird.
P粉197639753
P粉197639753 2023-11-17 14:54:42
0
2
1155

Bevor ich die Seite für eine bestimmte Route rendere, möchte ich zunächst die notwendigen Daten synchron abrufen. Idealerweise möchte ich die Daten in der Seitenkomponente abrufen, habe aber nichts dagegen, dies in der Router-Datei zu tun. Ich habe verschiedene Ansätze gelesen und ausprobiert, aber ein Teil der Herausforderung ergibt sich aus der Tatsache, dass es mehrere Möglichkeiten zum Erstellen von Komponenten gibt und die Verwendung bestimmter Funktionen unterschiedlich ist.

In meinem Fall verwende ich die Composition API und

P粉197639753
P粉197639753

Antworte allen(2)
P粉546257913

首先,beforeRouteUpdate仅在更新实际路由时触发,但不会像官方那样转到另一个组件/页面这里告诉

关于什么可能触发生命周期挂钩的示例是

<button @click="$router.push({ hash: `#${Math.floor(Math.random() * 10)}` })">
  random hash
</button>

onBeforeRouteLeave 完美地工作,正如你所期望的那样,从一个页面移动到另一个页面时。

对于最初的问题,您可以实现某种路由器中间件 就像 Nuxt 做到了。这样,您就可以等待 HTTP 调用,并且只有在那时才允许实际导航。因此几乎可以创建块导航效果。

我不确定如何使用 Composition API 编写它,但我知道它可以与 Options API 完美配合(有很多可用的博客文章)。 setup 本身以它自己的生命周期方式运行,我想很多事情都相当棘手。

TLDR:在我看来,一个好的路由器中间件+页面包装器(如布局)是您案例中的完美组合。在那里,您可以同时为相当多的页面设置一个观察者。

但是一切都取决于您想要如何组织自己并构建代码。


骨架屏幕给人一种比阻塞更快的感觉,但总的来说,您也可以使用 prefetch (默认情况下也随 Nuxt 一起提供)以获得一些提示并可能在需要某些资源之前加载它们。 (+同一域中的其他技巧来加速您的网络请求)

P粉545956597

有一个解决方案 - 使用顶级等待 - https ://vuejs.org/api/sfc-script-setup.html#top-level-await

只需将 RouterView 组件包装在 Suspense 组件中,如下所示 - https://vuejs.org/guide/built-ins/suspense.html#combining-with-other-components(不要使用不需要的组件)

唯一需要注意的是,“加载屏幕”将在初始请求时可见。

我为您做了一个小演示,以便您可以尝试一下 - https ://github.com/ileue/vue-top-level-await-demo

Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage