UIAbility組件生命周期

2024-01-25 12:14 更新

概述

當(dāng)用戶打開、切換和返回到對(duì)應(yīng)應(yīng)用時(shí),應(yīng)用中的UIAbility實(shí)例會(huì)在其生命周期的不同狀態(tài)之間轉(zhuǎn)換。UIAbility類提供了一系列回調(diào),通過(guò)這些回調(diào)可以知道當(dāng)前UIAbility實(shí)例的某個(gè)狀態(tài)發(fā)生改變,會(huì)經(jīng)過(guò)UIAbility實(shí)例的創(chuàng)建和銷毀,或者UIAbility實(shí)例發(fā)生了前后臺(tái)的狀態(tài)切換。

UIAbility的生命周期包括Create、Foreground、Background、Destroy四個(gè)狀態(tài),如下圖所示。

圖1 UIAbility生命周期狀態(tài)

生命周期狀態(tài)說(shuō)明

Create狀態(tài)

Create狀態(tài)為在應(yīng)用加載過(guò)程中,UIAbility實(shí)例創(chuàng)建完成時(shí)觸發(fā),系統(tǒng)會(huì)調(diào)用onCreate()回調(diào)??梢栽谠摶卣{(diào)中進(jìn)行應(yīng)用初始化操作,例如變量定義資源加載等,用于后續(xù)的UI界面展示。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. import Window from '@ohos.window';
  3. export default class EntryAbility extends UIAbility {
  4. onCreate(want, launchParam) {
  5. // 應(yīng)用初始化
  6. }
  7. // ...
  8. }

WindowStageCreate和WindowStageDestroy狀態(tài)

UIAbility實(shí)例創(chuàng)建完成之后,在進(jìn)入Foreground之前,系統(tǒng)會(huì)創(chuàng)建一個(gè)WindowStage。WindowStage創(chuàng)建完成后會(huì)進(jìn)入onWindowStageCreate()回調(diào),可以在該回調(diào)中設(shè)置UI界面加載、設(shè)置WindowStage的事件訂閱。

圖2 WindowStageCreate和WindowStageDestroy狀態(tài)

在onWindowStageCreate()回調(diào)中通過(guò)loadContent()方法設(shè)置應(yīng)用要加載的頁(yè)面并根據(jù)需要訂閱WindowStage的事件(獲焦/失焦、可見/不可見)。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. import Window from '@ohos.window';
  3. export default class EntryAbility extends UIAbility {
  4. onWindowStageCreate(windowStage: Window.WindowStage) {
  5. // 設(shè)置WindowStage的事件訂閱(獲焦/失焦、可見/不可見)
  6. // 設(shè)置UI界面加載
  7. windowStage.loadContent('pages/Index', (err, data) => {
  8. // ...
  9. });
  10. }
  11. }
說(shuō)明

WindowStage的相關(guān)使用請(qǐng)參見窗口開發(fā)指導(dǎo)。

對(duì)應(yīng)于onWindowStageCreate()回調(diào)。在UIAbility實(shí)例銷毀之前,則會(huì)先進(jìn)入onWindowStageDestroy()回調(diào),可以在該回調(diào)中釋放UI界面資源。例如在onWindowStageDestroy()中注銷獲焦/失焦等WindowStage事件。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. import Window from '@ohos.window';
  3. export default class EntryAbility extends UIAbility {
  4. // ...
  5. onWindowStageDestroy() {
  6. // 釋放UI界面資源
  7. }
  8. }

Foreground和Background狀態(tài)

Foreground和Background狀態(tài)分別在UIAbility實(shí)例切換至前臺(tái)和切換至后臺(tái)時(shí)觸發(fā),對(duì)應(yīng)于onForeground()回調(diào)和onBackground()回調(diào)。

onForeground()回調(diào),在UIAbility的UI界面可見之前,如UIAbility切換至前臺(tái)時(shí)觸發(fā)??梢栽趏nForeground()回調(diào)中申請(qǐng)系統(tǒng)需要的資源,或者重新申請(qǐng)?jiān)趏nBackground()中釋放的資源。

onBackground()回調(diào),在UIAbility的UI界面完全不可見之后,如UIAbility切換至后臺(tái)時(shí)候觸發(fā)。可以在onBackground()回調(diào)中釋放UI界面不可見時(shí)無(wú)用的資源,或者在此回調(diào)中執(zhí)行較為耗時(shí)的操作,例如狀態(tài)保存等。

例如應(yīng)用在使用過(guò)程中需要使用用戶定位時(shí),假設(shè)應(yīng)用已獲得用戶的定位權(quán)限授權(quán)。在UI界面顯示之前,可以在onForeground()回調(diào)中開啟定位功能,從而獲取到當(dāng)前的位置信息。

當(dāng)應(yīng)用切換到后臺(tái)狀態(tài),可以在onBackground()回調(diào)中停止定位功能,以節(jié)省系統(tǒng)的資源消耗。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. export default class EntryAbility extends UIAbility {
  3. onForeground() {
  4. // 申請(qǐng)系統(tǒng)需要的資源,或者重新申請(qǐng)?jiān)趏nBackground中釋放的資源
  5. }
  6. onBackground() {
  7. // 釋放UI界面不可見時(shí)無(wú)用的資源,或者在此回調(diào)中執(zhí)行較為耗時(shí)的操作
  8. // 例如狀態(tài)保存等
  9. }
  10. }

Destroy狀態(tài)

Destroy狀態(tài)在UIAbility實(shí)例銷毀時(shí)觸發(fā)??梢栽趏nDestroy()回調(diào)中進(jìn)行系統(tǒng)資源的釋放、數(shù)據(jù)的保存等操作。

例如調(diào)用terminateSelf()方法停止當(dāng)前UIAbility實(shí)例,從而完成UIAbility實(shí)例的銷毀;或者用戶使用最近任務(wù)列表關(guān)閉該UIAbility實(shí)例,完成UIAbility的銷毀。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. import Window from '@ohos.window';
  3. export default class EntryAbility extends UIAbility {
  4. onDestroy() {
  5. // 系統(tǒng)資源的釋放、數(shù)據(jù)的保存等
  6. }
  7. }
以上內(nèi)容是否對(duì)您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號(hào)
微信公眾號(hào)

編程獅公眾號(hào)