鸿蒙5.0开发进阶:Stage模型-@ohos.app.ability.abilityLifecycleCallback (AbilityLifecycleCallback)

往期鸿蒙全套实战文章必看:(文中附带全栈鸿蒙学习资料)


@ohos.app.ability.abilityLifecycleCallback (AbilityLifecycleCallback)

AbilityLifecycleCallback模块提供应用上下文ApplicationContext的生命周期发生变化时触发相应回调的能力。

说明

本模块首批接口从API version 9 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。

本模块接口仅可在Stage模型下使用。

导入模块

import { AbilityLifecycleCallback } from '@kit.AbilityKit';

AbilityLifecycleCallback.onAbilityCreate

onAbilityCreate(ability: UIAbility): void

注册监听应用上下文的生命周期后,在ability创建时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onWindowStageCreate

onWindowStageCreate(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在windowStage创建时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onWindowStageActive

onWindowStageActive(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在windowStage获焦时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onWindowStageInactive

onWindowStageInactive(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在windowStage失焦时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onWindowStageDestroy

onWindowStageDestroy(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在windowStage销毁时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onAbilityDestroy

onAbilityDestroy(ability: UIAbility): void

注册监听应用上下文的生命周期后,在ability销毁时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityForeground

onAbilityForeground(ability: UIAbility): void

注册监听应用上下文的生命周期后,在ability的状态从后台转到前台时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityBackground

onAbilityBackground(ability: UIAbility): void

注册监听应用上下文的生命周期后,在ability的状态从前台转到后台时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityContinue

onAbilityContinue(ability: UIAbility): void

注册监听应用上下文的生命周期后,在ability迁移时触发回调。

元服务API: 从API version 11开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityWillCreate12+

onAbilityWillCreate?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onCreate触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onWindowStageWillCreate12+

onWindowStageWillCreate?(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在UIAbility的onWindowStageCreate触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onWindowStageWillDestroy12+

onWindowStageWillDestroy?(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在UIAbility的onWindowStageDestroy触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onAbilityWillForeground12+

onAbilityWillForeground?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onForeground触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityWillDestroy12+

onAbilityWillDestroy?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onDestroy触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityWillBackground12+

onAbilityWillBackground?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onBackground触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onWillNewWant12+

onWillNewWant?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onNewWant触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onNewWant12+

onNewWant?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onNewWant触发后回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilityWillContinue12+

onAbilityWillContinue?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onContinue触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onWindowStageWillRestore12+

onWindowStageWillRestore?(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在UIAbility的onWindowStageRestore触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onWindowStageRestore12+

onWindowStageRestore?(ability: UIAbility, windowStage: window.WindowStage): void

注册监听应用上下文的生命周期后,在UIAbility的onWindowStageRestore触发后回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象
windowStagewindow.WindowStage当前WindowStage对象

AbilityLifecycleCallback.onAbilityWillSaveState12+

onAbilityWillSaveState?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onSaveState触发前回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback.onAbilitySaveState12+

onAbilitySaveState?(ability: UIAbility): void

注册监听应用上下文的生命周期后,在UIAbility的onSaveState触发后回调。

元服务API: 从API version 12开始,该接口支持在元服务中使用。

系统能力:SystemCapability.Ability.AbilityRuntime.AbilityCore

参数:

参数名类型必填说明
abilityUIAbility当前Ability对象

AbilityLifecycleCallback使用

示例:

GlobalContext.ts

全局Context

// 构造单例对象
export class GlobalContext {
  private constructor() {}
  private static instance: GlobalContext;
  private _objects = new Map<string, Object>();

  public static getContext(): GlobalContext {
    if (!GlobalContext.instance) {
      GlobalContext.instance = new GlobalContext();
    }
    return GlobalContext.instance;
  }

  getObject(value: string): Object | undefined {
    return this._objects.get(value);
  }

  setObject(key: string, objectClass: Object): void {
    this._objects.set(key, objectClass);
  }
}

MyFirstAbility.ts

应用的第一个Ability

import { AbilityLifecycleCallback, UIAbility } from '@kit.AbilityKit';
import { window } from '@kit.ArkUI';

// 导入GlobalContext,以开发者自己声明的路径为准
import { GlobalContext } from '../GlobalContext'

// 声明ability生命周期回调,需配置所有回调后才可以在applicationContext注册
let abilityLifecycleCallback: AbilityLifecycleCallback = {
  onAbilityCreate(ability){
    console.log('AbilityLifecycleCallback onAbilityCreate.');
  },
  onWindowStageCreate(ability, windowStage){
    console.log('AbilityLifecycleCallback onWindowStageCreate.');
  },
  onWindowStageActive(ability, windowStage){
    console.log('AbilityLifecycleCallback onWindowStageActive.');
  },
  onWindowStageInactive(ability, windowStage){
    console.log('AbilityLifecycleCallback onWindowStageInactive.');
  },
  onWindowStageDestroy(ability, windowStage){
    console.log('AbilityLifecycleCallback onWindowStageDestroy.');
  },
  onAbilityDestroy(ability){
    console.log('AbilityLifecycleCallback onAbilityDestroy.');
  },
  onAbilityForeground(ability){
    console.log('AbilityLifecycleCallback onAbilityForeground.');
  },
  onAbilityBackground(ability){
    console.log('AbilityLifecycleCallback onAbilityBackground.');
  },
  onAbilityContinue(ability){
    console.log('AbilityLifecycleCallback onAbilityContinue.');
  },
  onNewWant(ability) {
    console.log('AbilityLifecycleCallback onNewWant');
  },
  onWillNewWant(ability) {
    console.log('AbilityLifecycleCallback onWillNewWant');
  },
  onAbilityWillCreate(ability) {
    console.log('AbilityLifecycleCallback onAbilityWillCreate');
  },
  onWindowStageWillCreate(ability, windowStage) {
    console.log('AbilityLifecycleCallback onWindowStageWillCreate');
  },
  onWindowStageWillDestroy(ability, windowStage) {
    console.log('AbilityLifecycleCallback onWindowStageWillDestroy');
  },
  onAbilityWillDestroy(ability) {
    console.log('AbilityLifecycleCallback onAbilityWillDestroy');
  },
  onAbilityWillForeground(ability) {
    console.log('AbilityLifecycleCallback onAbilityWillForeground');
  },
  onAbilityWillBackground(ability) {
    console.log('AbilityLifecycleCallback onAbilityWillBackground');
  },
  onAbilityWillContinue(ability: UIAbility) {
    console.log('AbilityLifecycleCallback onAbilityWillContinue.');
  },
  onWindowStageWillRestore(ability: UIAbility, windowStage: window.WindowStage) {
    console.log('AbilityLifecycleCallback onWindowStageWillRestore.');
  },
  onWindowStageRestore(ability: UIAbility, windowStage: window.WindowStage) {
    console.log('AbilityLifecycleCallback onWindowStageRestore.');
  },
  onAbilityWillSaveState(ability: UIAbility) {
    console.log('AbilityLifecycleCallback onAbilityWillSaveState.');
  },
  onAbilitySaveState(ability: UIAbility) {
    console.log('AbilityLifecycleCallback onAbilitySaveState.');
  }
};

export default class MyFirstAbility extends UIAbility {
  onCreate() {
    console.log('MyAbilityStage onCreate');
    // 1.通过context属性获取applicationContext
    let applicationContext = this.context.getApplicationContext();
    // 2.通过applicationContext注册监听应用内生命周期
    try {
      let lifecycleId = applicationContext.on('abilityLifecycle', abilityLifecycleCallback);
      GlobalContext.getContext().setObject("lifecycleId", lifecycleId);
      console.log(`registerAbilityLifecycleCallback lifecycleId: ${GlobalContext.getContext().getObject('lifecycleId')}`);
    } catch (paramError) {
      console.error(`error: ${paramError.code}, ${paramError.message}`);
    }
  }
}

MySecondAbility.ts

应用的第二个Ability

import { UIAbility } from '@kit.AbilityKit';

// 导入GlobalContext,以开发者自己声明的路径为准
import { GlobalContext } from '../GlobalContext'
import { BusinessError } from '@ohos.base';

export default class MySecondAbility extends UIAbility {
onDestroy() {
let applicationContext = this.context.getApplicationContext();
let lifecycleId = GlobalContext.getContext().getObject("lifecycleId") as number;
try {
// 3.通过applicationContext注销监听应用内生命周期
applicationContext.off('abilityLifecycle', lifecycleId, (error) => {
if (error && error.code !== 0) {
console.error(`unregisterAbilityLifecycleCallback fail, error: ${JSON.stringify(error)}`);
} else {
console.log('unregisterAbilityLifecycleCallback success.');
}
});
} catch (paramError) {
console.error(`error: ${(paramError as BusinessError).code}, ${(paramError as BusinessError).message}`);
}
}
}
 

ysql001 ~]# yum install zabbix-web-mysql-scl zabbix-apache-conf-scl \Loaded plugins: fastestmirror Loading mirror speeds from cached hostfile Resolving Dependencies --> Running transaction check ---> Package zabbix-apache-conf-scl.noarch 0:5.0.47-1.el7 will be installed --> Processing Dependency: zabbix-web-deps-scl = 5.0.47-1.el7 for package: zabbix-apache-conf-scl-5.0.47-1.el7.noarch ---> Package zabbix-web-mysql-scl.noarch 0:5.0.47-1.el7 will be installed --> Processing Dependency: rh-php72-php-mysqlnd for package: zabbix-web-mysql-scl-5.0.47-1.el7.noarch --> Running transaction check ---> Package zabbix-web-deps-scl.noarch 0:5.0.47-1.el7 will be installed --> Processing Dependency: rh-php72 for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-bcmath for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-fpm for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-gd for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-ldap for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-mbstring for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch --> Processing Dependency: rh-php72-php-xml for package: zabbix-web-deps-scl-5.0.47-1.el7.noarch ---> Package zabbix-web-mysql-scl.noarch 0:5.0.47-1.el7 will be installed --> Processing Dependency: rh-php72-php-mysqlnd for package: zabbix-web-mysql-scl-5.0.47-1.el7.noarch --> Finished Dependency Resolution Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-fpm Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-ldap Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-xml Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-mbstring Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-bcmath Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-gd Error: Package: zabbix-web-mysql-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72-php-mysqlnd Error: Package: zabbix-web-deps-scl-5.0.47-1.el7.noarch (zabbix-frontend) Requires: rh-php72 You could try using --skip-broken to work around the problem You could try running: rpm -Va --nofiles --nodigest为啥
08-01
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值