React Lifecycle
本指南讨论如何在 Ionic React 应用程序中使用 Ionic 生命周期事件。
Ionic 生命周期方法
Ionic 提供了一些可以在应用程序中使用的生命周期方法:
| 事件名称 | 描述 |
|---|---|
ionViewWillEnter | 当即将路由到的组件准备以动画形式进入视图时触发。 |
ionViewDidEnter | 当路由到的组件已完成动画进入时触发。 |
ionViewWillLeave | 当即将路由离开的组件准备以动画形式退出时触发。 |
ionViewDidLeave | 当路由离开的组件已完成动画退出时触发。 |
这些生命周期仅会在直接由路由映射的组件上调用。这意味着如果 /pageOne 映射到 PageOneComponent,那么 Ionic 生命周期将在 PageOneComponent 上调用,但不会在 PageOneComponent 可能渲染的任何子组件上调用。
访问这些方法的方式取决于您使用的是基于类的组件还是函数式组件。我们在下文中涵盖了这两种方法。
基于类组件中的生命周期方法
要在基于类的组件中使用 Ionic 生命周期方法,必须使用 withIonLifeCycle 高阶组件(HOC)包装您的组件,如下所示:
export default withIonLifeCycle(HomePage);
withIonLifeCycle 是从 @ionic/react 导入的。
然后,您可以在类组件上创建相应的生命周期方法,当事件发生时,高阶组件会调用该方法。以下是实现了所有生命周期方法的完整组件:
import React from 'react';
import { IonHeader, IonPage, IonToolbar, IonTitle, IonContent, withIonLifeCycle } from '@ionic/react';
class HomePage extends React.Component {
ionViewWillEnter() {
console.log('ionViewWillEnter event fired');
}
ionViewWillLeave() {
console.log('ionViewWillLeave event fired');
}
ionViewDidEnter() {
console.log('ionViewDidEnter event fired');
}
ionViewDidLeave() {
console.log('ionViewDidLeave event fired');
}
render() {
return (
<IonPage>
<IonHeader>
<IonToolbar>
<IonTitle>Home</IonTitle>
</IonToolbar>
</IonHeader>
<IonContent></IonContent>
</IonPage>
);
}
}
export default withIonLifeCycle(HomePage);
函数式组件中的生命周期方法
Ionic React 为每个生命周期方法导出了钩子,您可以在函数式组件中使用。每个钩子都接受一个函数,该函数将在事件触发时被调用。
import {
IonContent,
IonHeader,
IonTitle,
IonToolbar,
useIonViewDidEnter,
useIonViewDidLeave,
useIonViewWillEnter,
useIonViewWillLeave,
} from '@ionic/react';
import React from 'react';
const HomePage: React.FC = () => {
useIonViewDidEnter(() => {
console.log('ionViewDidEnter event fired');
});
useIonViewDidLeave(() => {
console.log('ionViewDidLeave event fired');
});
useIonViewWillEnter(() => {
console.log('ionViewWillEnter event fired');
});
useIonViewWillLeave(() => {
console.log('ionViewWillLeave event fired');
});
return (
<IonPage>
<IonHeader>
<IonToolbar>
<IonTitle>Home</IonTitle>
</IonToolbar>
</IonHeader>
<IonContent></IonContent>
</IonPage>
);
};
export default HomePage;
函数式组件不需要像类组件那样用 withIonLifeCycle 高阶组件包 装。
开发者还可以选择性地向每个生命周期钩子传递响应式依赖项。这些依赖项随后会传递给底层的 React useEffect 钩子:
const [data, setData] = useState('foo');
useIonViewDidEnter(() => {
console.log('ionViewDidEnter event fired');
}, [data]);
React 生命周期方法
所有 React 生命周期方法(componentDidMount、componentWillUnmount 等)也均可供使用。然而,由于 Ionic React 管理页面的生命周期,某些事件可能不会在您预期的时候触发。例如,componentDidMount 在页面首次显示时触发,但如果您从页面导航离开,Ionic 可能会将页面保留在 DOM 中,导致再次访问该页面时可能不会再次调用 componentDidMount。这种情况是 Ionic 生命周期方法存在的主要原因,以便在原生框架的事件可能不触发时,仍能为您提供一种在视图进入和退出时调用逻辑的方式。
各生命周期方法的使用建议
以下是关于每个生命周期事件使用场景的一些建议:
ionViewWillEnter- 由于ionViewWillEnter在每次导航到该视图时都会被调用(无论是否已初始化),因此它是从服务加载数据的好方法。ionViewDidEnter- 如果您在使用ionViewWillEnter加载数据时遇到性能问题,可以改为在ionViewDidEnter中进行数据调用。然而,此事件要等到页面对用户可见后才会触发,因此您可能需要使用加载指示器或骨架屏,以避免内容在过渡完成后不自然地闪现。ionViewWillLeave- 可用于清理工作,例如取消订阅数据源。由于componentWillUnmount在您从当前页面导航离开时可能不会触发,因此如果您不希望清理代码在屏幕不可见时仍处于活动状态,请将清理代码放在此处。ionViewDidLeave- 当此事件触发时,您知道新页面已经完全过渡完毕,因此任何通常不会在视图可见时执行的逻辑都可以放在这里。
在页面之间传递状态
由于 Ionic React 管理页面的生命周期,当用户在应用程序中导航时,先前页面上的状态可能会更新。这可能会影响使用 React 的 useEffect 或 React Router 的 useLocation 确定的状态。例如,如果 PageA 调用了 useLocation,当用户从 PageA 导航到 PageB 时,useLocation 的状态将发生变化。
开发者应包含适当的检查,以确保先前页面仅访问已定义的状态。
例如,如果 testObject 未定义,以下代码将出错:{ state.testObject.childKey }
相反,开发者应仅在 testObject 已定义时才访问 childKey:{ state.testObject?.childKey }