跳到主要内容
版本:v8

Vue 生命周期

本指南将讨论如何在 Ionic Vue 应用程序中使用 Ionic Framework 生命周期事件。

Ionic Framework 生命周期方法

Ionic Framework 提供了一些可以在应用程序中使用的生命周期方法:

事件名称描述
ionViewWillEnter当即将进入视图的路由组件开始动画时触发。
ionViewDidEnter当进入视图的路由组件动画完成时触发。
ionViewWillLeave当即将离开视图的路由组件开始动画时触发。
ionViewDidLeave当离开视图的路由组件动画完成时触发。

这些生命周期方法仅适用于由路由器直接映射的组件。这意味着如果 /pageOne 映射到 PageOneComponent,那么 Ionic 生命周期方法将在 PageOneComponent 上调用,但不会在 PageOneComponent 可能渲染的任何子组件上调用。

这些生命周期的定义方式与 Vue 生命周期方法相同——作为 Vue 组件根级别的函数:

<script setup lang="ts">
import { IonPage } from '@ionic/vue';

const ionViewDidEnter = () => {
console.log('Home page did enter');
};

const ionViewDidLeave = () => {
console.log('Home page did leave');
};

const ionViewWillEnter = () => {
console.log('Home page will enter');
};

const ionViewWillLeave = () => {
console.log('Home page will leave');
};
</script>

组合式 API 钩子

这些生命周期也可以使用 Vue 3 的组合式 API 来表达:

<script setup lang="ts">
import { IonPage, onIonViewWillEnter, onIonViewDidEnter, onIonViewWillLeave, onIonViewDidLeave } from '@ionic/vue';

onIonViewDidEnter(() => {
console.log('Home page did enter');
});

onIonViewDidLeave(() => {
console.log('Home page did leave');
});

onIonViewWillEnter(() => {
console.log('Home page will enter');
});

onIonViewWillLeave(() => {
console.log('Home page will leave');
});
</script>
备注

应用程序中的页面需要使用 IonPage 组件,以确保生命周期方法和钩子能够正常触发。

Ionic Framework 如何处理页面的生命周期

Ionic Framework 拥有自己的路由器出口,称为 <ion-router-outlet>。这个出口扩展了 Vue Router 的 <router-view>,并添加了一些额外的功能,以便为移动设备提供更好的体验。

当应用程序被包裹在 <ion-router-outlet> 中时,Ionic Framework 对导航的处理会略有不同。当你导航到一个新页面时,Ionic Framework 会将旧页面保留在现有的 DOM 中,但从视图中隐藏它,并过渡到新页面。我们这样做的原因有两个:

  1. 我们可以保持旧页面的状态(屏幕上的数据、滚动位置等)。
  2. 我们可以提供更平滑的返回过渡,因为旧页面已经存在,无需重新创建。

只有当页面被“弹出”时(例如,通过用户界面中的返回按钮或浏览器的返回按钮),页面才会从 DOM 中移除。

由于这种特殊处理,某些 Vue Router 组件(如 <keep-alive><transition><router-view>)不应在 Ionic Vue 应用程序中使用。此外,这里也不需要 Vue Router 的滚动行为 API,因为每个页面的滚动位置都会自动保存。

Vue 的所有生命周期方法(mountedbeforeUnmount 等)也都可以供你使用。然而,由于 Ionic Vue 管理页面的生命周期,某些事件可能不会在你预期的时候触发。例如,mounted 在页面首次显示时触发,但如果你从该页面导航离开,Ionic Framework 可能会将该页面保留在 DOM 中,后续再次访问该页面时可能不会再次调用 mounted。这种情况是 Ionic Framework 生命周期方法存在的主要原因,以便在原生命周期事件可能不触发时,仍能提供一种在视图进入和退出时调用逻辑的方式。

各生命周期方法的使用指导

以下是对每个生命周期事件使用场景的一些建议:

  • ionViewWillEnter - 由于 ionViewWillEnter 在每次导航到视图时都会被调用(无论是否初始化),因此它是从服务加载数据的好方法。
  • ionViewDidEnter - 如果在使用 ionViewWillEnter 加载数据时遇到性能问题,可以改用 ionViewDidEnter 进行数据调用。然而,此事件将在页面对用户可见之后才触发,因此你可能需要使用加载指示器或骨架屏(如 ion-skeleton-text),以避免内容在过渡完成后不自然地闪烁出现。
  • ionViewWillLeave - 可用于清理工作,例如取消订阅数据源。由于 beforeUnmount 在从当前页面导航时可能不会触发,因此如果你不希望清理代码在屏幕不可见时仍处于活动状态,可以将其放在这里。
  • ionViewDidLeave - 当此事件触发时,你知道新页面已经完全过渡完成,因此任何在视图不可见时通常不会执行的逻辑都可以放在这里。