harmony 鸿蒙@ohos.app.ability.AbilityStage (AbilityStage组件容器)
@ohos.app.ability.AbilityStage (AbilityStage组件容器)
AbilityStage是一个Module级别的组件容器,应用的HAP/HSP在首次加载时会创建一个AbilityStage实例,开发者可以通过该实例进行Module级别的资源预加载、线程创建等初始化操作。AbilityStage与Module一一对应,即一个Module拥有一个AbilityStage。
AbilityStage拥有onCreate()、onDestroy()生命周期回调和onAcceptWant()、onConfigurationUpdate()、onMemoryLevel()事件回调等。
说明:
本模块首批接口从API version 9 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
本模块接口仅可在Stage模型下使用。
导入模块
import { AbilityStage } from '@kit.AbilityKit';
属性
原子化服务API:从API version 11开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
名称 | 类型 | 只读 | 可选 | 说明 |
---|---|---|---|---|
context | AbilityStageContext | 否 | 否 | AbilityStage上下文。 |
AbilityStage.onCreate
onCreate(): void
在加载Module的第一个Ability实例前,系统会先创建对应的AbilityStage实例,并在AbilityStage创建完成后,自动触发该回调。
开发者可以在该回调中执行Module的初始化操作(如资源预加载、线程创建等)。同步接口,不支持异步回调。
原子化服务API:从API version 11开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
示例:
import { AbilityStage } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onCreate() {
console.log('MyAbilityStage.onCreate is called');
}
}
AbilityStage.onAcceptWant
onAcceptWant(want: Want): string
当启动模式配置为specified的UIAbility被拉起时,会触发该回调,并返回一个string作为待启动的UIAbility实例的唯一标识。同步接口,不支持异步回调。
如果系统中已经有相同标识的UIAbility实例存在,则复用已有实例,否则创建新的实例。
说明:
从API version 20开始,当AbilityStage.onAcceptWantAsync实现时,本回调函数将不执行。
原子化服务API:从API version 11开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
want | Want | 是 | Want类型参数,此处表示调用方传入的启动参数,如Ability名称,Bundle名称等。 |
返回值:
类型 | 说明 |
---|---|
string | 返回开发者自定义的UIAbility标识。如果已经启动了相同标识的UIAbility,则复用该UIAbility,否则创建新的实例并启动。 |
示例:
import { AbilityStage, Want } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onAcceptWant(want: Want) {
console.log('MyAbilityStage.onAcceptWant called');
return 'com.example.test';
}
}
AbilityStage.onNewProcessRequest11+
onNewProcessRequest(want: Want): string
在指定进程中启动UIAbility时,会触发该回调。同步接口,不支持异步回调。
说明:
从API version 20开始,当AbilityStage.onNewProcessRequestAsync实现时,本回调函数将不执行。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
want | Want | 是 | Want类型参数,此处表示调用方传入的启动参数,如Ability名称,Bundle名称等。 |
返回值:
类型 | 说明 |
---|---|
string | 返回一个由开发者自行决定的进程字符串标识,如果之前此标识对应的进程已被创建,就让ability在此进程中运行,否则创建新的进程。 |
示例:
import { AbilityStage, Want } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onNewProcessRequest(want: Want) {
console.log('MyAbilityStage.onNewProcessRequest called');
return 'com.example.test';
}
}
AbilityStage.onConfigurationUpdate
onConfigurationUpdate(newConfig: Configuration): void
当系统全局配置(例如系统语言、深浅色等)发生变更时,会触发该回调。配置项均定义在Configuration类中。同步接口,不支持异步回调。
原子化服务API:从API version 11开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
newConfig | Configuration | 是 | 发生全局配置变更时触发回调,当前全局配置包括系统语言、深浅色模式。 |
示例:
import { AbilityStage, Configuration } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onConfigurationUpdate(config: Configuration) {
console.log(`MyAbilityStage.onConfigurationUpdate, language: ${config.language}`);
}
}
AbilityStage.onMemoryLevel
onMemoryLevel(level: AbilityConstant.MemoryLevel): void
该接口用于监听系统内存状态变化。当系统检测到内存资源紧张时,将主动触发该回调。开发者可通过实现此接口,在收到内存紧张事件时,及时释放非必要资源(如缓存数据、临时对象等),以避免应用进程被系统强制终止。
同步接口,不支持异步回调。
原子化服务API:从API version 11开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
level | AbilityConstant.MemoryLevel | 是 | 回调返回内存微调级别,显示当前内存使用状态。 说明: 不同产品的触发条件可能存在差异。以12G内存的标准设备为例: - 当可用内存下降至1700M~1800M时,会触发取值为0的onMemoryLevel回调。 - 当可用内存下降至1600M~1700M时,会触发取值为1的onMemoryLevel回调。 - 当可用内存下降至1600M以下时,会触发取值为2的onMemoryLevel回调。 |
示例:
import { AbilityStage, AbilityConstant } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onMemoryLevel(level: AbilityConstant.MemoryLevel) {
console.log(`MyAbilityStage.onMemoryLevel, level: ${JSON.stringify(level)}`);
}
}
AbilityStage.onDestroy12+
onDestroy(): void
在对应Module的最后一个Ability实例退出后会触发该回调。此方法将在正常的调度生命周期中调用,当应用程序异常退出或被终止时,将不会调用此方法。同步接口,不支持异步回调。
原子化服务API:从API version 12开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
示例:
import { AbilityStage } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onDestroy() {
console.log('MyAbilityStage.onDestroy is called');
}
}
AbilityStage.onPrepareTermination15+
onPrepareTermination(): AbilityConstant.PrepareTermination
当应用被用户关闭时调用,可用于询问用户选择立即执行操作还是取消操作。同步接口,不支持异步回调。
说明:
当前仅在2in1设备上生效。
仅当应用正常退出(例如,通过doc栏/托盘关闭应用,或者应用随设备关机而退出)时会调用该接口。如果应用被强制关闭,则不会调用该接口。
当AbilityStage.onPrepareTerminationAsync实现时,本回调函数将不执行。
需要权限:ohos.permission.PREPARE_APP_TERMINATE
原子化服务API:从API version 15开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
返回值:
类型 | 说明 |
---|---|
AbilityConstant.PrepareTermination | 用于返回用户的选择结果。 |
示例:
import { AbilityConstant, AbilityStage } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
onPrepareTermination(): AbilityConstant.PrepareTermination {
console.info('MyAbilityStage.onPrepareTermination is called');
return AbilityConstant.PrepareTermination.CANCEL;
}
}
AbilityStage.onPrepareTerminationAsync15+
onPrepareTerminationAsync(): Promise<AbilityConstant.PrepareTermination>
当应用被用户关闭时调用,可用于询问用户选择立即执行操作还是取消操作。使用Promise异步回调。
说明:
当前仅在2in1设备上生效。
仅当应用正常退出(例如,通过doc栏/托盘关闭应用,或者应用随设备关机而退出)时会调用该接口。如果应用被强制关闭,则不会调用该接口。
若异步回调内发生crash,按超时处理,执行等待超过10秒未响应,应用将被强制关闭。
需要权限:ohos.permission.PREPARE_APP_TERMINATE
原子化服务API:从API version 15开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
返回值:
类型 | 说明 |
---|---|
Promise<AbilityConstant.PrepareTermination> | Promise对象,返回用户的选择结果。 |
示例:
import { AbilityConstant, AbilityStage } from '@kit.AbilityKit';
export default class MyAbilityStage extends AbilityStage {
async onPrepareTerminationAsync(): Promise<AbilityConstant.PrepareTermination> {
await new Promise<AbilityConstant.PrepareTermination>((res, rej) => {
setTimeout(res, 3000); // 延时3秒后执行
});
return AbilityConstant.PrepareTermination.CANCEL;
}
}
AbilityStage.onAcceptWantAsync20+
onAcceptWantAsync(want: Want): Promise<string>
当启动模式配置为specified的UIAbility被拉起时,会触发该回调,并返回一个string作为待启动的UIAbility实例的唯一标识。使用Promise异步回调。
如果系统中已经有相同标识的UIAbility实例存在,则复用已有实例,否则创建新的实例。详见:specified启动模式。
原子化服务API:从API version 20开始,该接口支持在原子化服务中使用。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
want | Want | 是 | Want类型参数,传入需要启动的UIAbility的信息,如UIAbility名称、Bundle名称等。 |
返回值:
类型 | 说明 |
---|---|
Promise<string> | Promise对象,返回一个string作为待启动的UIAbility实例的唯一标识。如果系统中已经有该标识的UIAbility实例存在,则复用已有实例,否则创建新的实例。 |
示例:
import { AbilityStage } from '@kit.AbilityKit';
class MyAbilityStage extends AbilityStage {
async onAcceptWantAsync(): Promise<string> {
await new Promise<string>((res, rej) => {
setTimeout(res, 1000); // 延时1秒后执行
});
return 'default';
}
}
AbilityStage.onNewProcessRequestAsync20+
onNewProcessRequestAsync(want: Want): Promise<string>
如果UIAbility配置了在独立进程中运行(即module.json5配置文件中UIAbility的isolationProcess字段取值为true),当该UIAbility被拉起时,会触发该回调,并返回一个string作为进程唯一标识。使用Promise异步回调。
如果该应用已有相同标识的进程存在,则待启动的UIAbility运行在此进程中,否则创建新的进程。
该接口仅在2in1和tablet设备上生效。
系统能力:SystemCapability.Ability.AbilityRuntime.Core
参数:
参数名 | 类型 | 必填 | 说明 |
---|---|---|---|
want | Want | 是 | Want类型参数,传入需要启动的UIAbility的信息,如UIAbility名称、Bundle名称等。 |
返回值:
类型 | 说明 |
---|---|
Promise<string> | Promise对象,返回一个由开发者自定义的进程字符串标识。如果该应用已有相同标识的进程存在,则UIAbility在此进程中运行,否则创建新的进程。 |
示例:
import { AbilityStage } from '@kit.AbilityKit';
class MyAbilityStage extends AbilityStage {
async onNewProcessRequestAsync(): Promise<string> {
await new Promise<string>((res, rej) => {
setTimeout(res, 1000); // 延时1秒后执行
});
return '';
}
}
你可能感兴趣的鸿蒙文章
harmony 鸿蒙OH_NativeBundle_ApplicationInfo
harmony 鸿蒙OH_NativeBundle_ElementName
harmony 鸿蒙ability_base_common.h
- 所属分类: 后端技术
- 本文标签:
热门推荐
-
2、 - 优质文章
-
3、 gate.io
-
8、 golang
-
9、 openharmony
-
10、 Vue中input框自动聚焦