提供组件创建、销毁、前后台切换等生命周期回调

2024-01-22 18:57 更新

UIAbility是包含UI界面的应用组件,提供组件创建、销毁、前后台切换等生命周期回调,同时也具备组件协同的能力,组件协同主要提供如下常用功能:

  • Caller:由startAbilityByCall接口返回,CallerAbility(调用者)可使用Caller与CalleeAbility(被调用者)进行通信。
  • Callee:UIAbility的内部对象,CalleeAbility(被调用者)可以通过Callee与Caller进行通信。
说明

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

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

导入模块

  1. import Ability from '@ohos.app.ability.UIAbility';

属性

系统能力:以下各项对应的系统能力均为SystemCapability.Ability.AbilityRuntime.AbilityCore

名称类型可读可写说明
contextUIAbilityContext上下文。
launchWantWantUIAbility启动时的参数。
lastRequestWantWantUIAbility最后请求时的参数。
calleeCallee调用Stub(桩)服务对象。

UIAbility.onCreate

onCreate(want: Want, param: AbilityConstant.LaunchParam): void;

Ability创建时回调,执行初始化业务逻辑操作。

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

参数:

参数名类型必填说明
wantWant当前UIAbility的Want类型信息,包括ability名称、bundle名称等。
paramAbilityConstant.LaunchParam创建UIAbility、上次异常退出的原因信息。

示例:

  1. class myAbility extends Ability {
  2. onCreate(want, param) {
  3. console.log('onCreate, want:' + want.abilityName);
  4. }
  5. }

UIAbility.onWindowStageCreate

onWindowStageCreate(windowStage: window.WindowStage): void

当WindowStage创建后调用。

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

参数:

参数名类型必填说明
windowStagewindow.WindowStageWindowStage相关信息。

示例:

  1. class myAbility extends Ability {
  2. onWindowStageCreate(windowStage) {
  3. console.log('onWindowStageCreate');
  4. }
  5. }

UIAbility.onWindowStageDestroy

onWindowStageDestroy(): void

当WindowStage销毁后调用。

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

示例:

  1. class myAbility extends Ability {
  2. onWindowStageDestroy() {
  3. console.log('onWindowStageDestroy');
  4. }
  5. }

UIAbility.onWindowStageRestore

onWindowStageRestore(windowStage: window.WindowStage): void

当迁移多实例ability时,恢复WindowStage后调用。

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

参数:

参数名类型必填说明
windowStagewindow.WindowStageWindowStage相关信息。

示例:

  1. class myAbility extends Ability {
  2. onWindowStageRestore(windowStage) {
  3. console.log('onWindowStageRestore');
  4. }
  5. }

UIAbility.onDestroy

onDestroy(): void | Promise<void>;

Ability生命周期回调,在销毁时回调,执行资源清理等操作。

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

示例:

  1. class myAbility extends Ability {
  2. onDestroy() {
  3. console.log('onDestroy');
  4. }
  5. }

UIAbility.onForeground

onForeground(): void;

Ability生命周期回调,当应用从后台转到前台时触发。

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

示例:

  1. class myAbility extends Ability {
  2. onForeground() {
  3. console.log('onForeground');
  4. }
  5. }

UIAbility.onBackground

onBackground(): void;

Ability生命周期回调,当应用从前台转到后台时触发。

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

示例:

  1. class myAbility extends Ability {
  2. onBackground() {
  3. console.log('onBackground');
  4. }
  5. }

UIAbility.onContinue

onContinue(wantParam: { [key: string]: Object }): AbilityConstant.OnContinueResult;

当ability迁移准备迁移时触发,保存数据。

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

参数:

参数名类型必填说明
wantParam{[key: string]: any}want相关参数。

返回值:

类型说明
AbilityConstant.OnContinueResult继续的结果。

示例:

  1. import AbilityConstant from '@ohos.app.ability.AbilityConstant';
  2. class MyUIAbility extends Ability {
  3. onContinue(wantParams) {
  4. console.log('onContinue');
  5. wantParams['myData'] = 'my1234567';
  6. return AbilityConstant.OnContinueResult.AGREE;
  7. }
  8. }

UIAbility.onNewWant

onNewWant(want: Want, launchParams: AbilityConstant.LaunchParam): void;

当传入新的Want,ability再次被拉起时会回调执行该方法。

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

参数:

参数名类型必填说明
wantWantWant类型参数,如ability名称,包名等。
launchParamsAbilityConstant.LaunchParamUIAbility启动的原因、上次异常退出的原因信息。

示例:

  1. class MyUIAbility extends Ability {
  2. onNewWant(want, launchParams) {
  3. console.log('onNewWant, want:' + want.abilityName);
  4. console.log('onNewWant, launchParams:' + JSON.stringify(launchParams));
  5. }
  6. }

UIAbility.onDump

onDump(params: Array<string>): Array<string>;

转储客户端信息时调用。

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

参数:

参数名类型必填说明
paramsArray<string>表示命令形式的参数。

示例:

  1. class myAbility extends Ability {
  2. onDump(params) {
  3. console.log('dump, params:' + JSON.stringify(params));
  4. return ['params'];
  5. }
  6. }

UIAbility.onSaveState

onSaveState(reason: AbilityConstant.StateType, wantParam : {[key: string]: Object}): AbilityConstant.OnSaveResult;

该API配合appRecovery使用。在应用故障时,如果使能了自动保存状态,框架将回调onSaveState保存Ability状态。

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

参数:

参数名类型必填说明
reasonAbilityConstant.StateType回调保存状态的原因。
wantParam{[key: string]: any}want相关参数。

返回值:

类型说明
AbilityConstant.OnSaveResult是否同意保存当前Ability的状态。

示例:

  1. import AbilityConstant from '@ohos.app.ability.AbilityConstant';
  2. class MyUIAbility extends Ability {
  3. onSaveState(reason, wantParam) {
  4. console.log('onSaveState');
  5. wantParam['myData'] = 'my1234567';
  6. return AbilityConstant.OnSaveResult.RECOVERY_AGREE;
  7. }
  8. }

Caller

通用组件Caller通信客户端调用接口, 用来向通用组件服务端发送约定数据。

Caller.call

call(method: string, data: rpc.Parcelable): Promise<void>;

向通用组件服务端发送约定序列化数据。

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

参数:

参数名类型必填说明
methodstring约定的服务端注册事件字符串。
datarpc.Parcelable由开发者实现的Parcelable可序列化数据。

返回值:

类型说明
Promise<void>Promise形式返回应答。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. class MyMessageAble{ // 自定义的Parcelable数据结构
  2. name:''
  3. str:''
  4. num: 1
  5. constructor(name, str) {
  6. this.name = name;
  7. this.str = str;
  8. }
  9. marshalling(messageSequence) {
  10. messageSequence.writeInt(this.num);
  11. messageSequence.writeString(this.str);
  12. console.log('MyMessageAble marshalling num[' + this.num + '] str[' + this.str + ']');
  13. return true;
  14. }
  15. unmarshalling(messageSequence) {
  16. this.num = messageSequence.readInt();
  17. this.str = messageSequence.readString();
  18. console.log('MyMessageAble unmarshalling num[' + this.num + '] str[' + this.str + ']');
  19. return true;
  20. }
  21. };
  22. let method = 'call_Function'; // 约定的通知消息字符串
  23. let caller;
  24. export default class MainAbility extends Ability {
  25. onWindowStageCreate(windowStage) {
  26. this.context.startAbilityByCall({
  27. bundleName: 'com.example.myservice',
  28. abilityName: 'MainAbility',
  29. deviceId: ''
  30. }).then((obj) => {
  31. caller = obj;
  32. let msg = new MyMessageAble('msg', 'world'); // 参考Parcelable数据定义
  33. caller.call(method, msg)
  34. .then(() => {
  35. console.log('Caller call() called');
  36. })
  37. .catch((callErr) => {
  38. console.log('Caller.call catch error, error.code: ' + JSON.stringify(callErr.code) +
  39. ' error.message: ' + JSON.stringify(callErr.message));
  40. });
  41. }).catch((err) => {
  42. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  43. ' error.message: ' + JSON.stringify(err.message));
  44. });
  45. }
  46. }

Caller.callWithResult

callWithResult(method: string, data: rpc.Parcelable): Promise<rpc.MessageSequence>;

向通用组件服务端发送约定序列化数据, 并将服务端返回的约定序列化数据带回。

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

参数:

参数名类型必填说明
methodstring约定的服务端注册事件字符串。
datarpc.Parcelable由开发者实现的Parcelable可序列化数据。

返回值:

类型说明
Promise<rpc.MessageSequence>Promise形式返回通用组件服务端应答数据。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. class MyMessageAble{
  2. name:''
  3. str:''
  4. num: 1
  5. constructor(name, str) {
  6. this.name = name;
  7. this.str = str;
  8. }
  9. marshalling(messageSequence) {
  10. messageSequence.writeInt(this.num);
  11. messageSequence.writeString(this.str);
  12. console.log('MyMessageAble marshalling num[' + this.num + '] str[' + this.str + ']');
  13. return true;
  14. }
  15. unmarshalling(messageSequence) {
  16. this.num = messageSequence.readInt();
  17. this.str = messageSequence.readString();
  18. console.log('MyMessageAble unmarshalling num[' + this.num + '] str[' + this.str + ']');
  19. return true;
  20. }
  21. };
  22. let method = 'call_Function';
  23. let caller;
  24. export default class MainAbility extends Ability {
  25. onWindowStageCreate(windowStage) {
  26. this.context.startAbilityByCall({
  27. bundleName: 'com.example.myservice',
  28. abilityName: 'MainAbility',
  29. deviceId: ''
  30. }).then((obj) => {
  31. caller = obj;
  32. let msg = new MyMessageAble(1, 'world');
  33. caller.callWithResult(method, msg)
  34. .then((data) => {
  35. console.log('Caller callWithResult() called');
  36. let retmsg = new MyMessageAble(0, '');
  37. data.readParcelable(retmsg);
  38. })
  39. .catch((callErr) => {
  40. console.log('Caller.callWithResult catch error, error.code: ' + JSON.stringify(callErr.code) +
  41. ' error.message: ' + JSON.stringify(callErr.message));
  42. });
  43. }).catch((err) => {
  44. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  45. ' error.message: ' + JSON.stringify(err.message));
  46. });
  47. }
  48. }

Caller.release

release(): void;

主动释放通用组件服务端的通信接口。

系统能力:SystemCapability.UIAbility.UIAbilityRuntime.UIAbilityCore

错误码:

错误码ID错误信息
401Invalid input parameter.
16200001Caller released. The caller has been released.
16200002Callee invalid. The callee does not exist.
16000050Internal Error.

示例:

  1. let caller;
  2. export default class MainAbility extends Ability {
  3. onWindowStageCreate(windowStage) {
  4. this.context.startAbilityByCall({
  5. bundleName: 'com.example.myservice',
  6. abilityName: 'MainAbility',
  7. deviceId: ''
  8. }).then((obj) => {
  9. caller = obj;
  10. try {
  11. caller.release();
  12. } catch (releaseErr) {
  13. console.log('Caller.release catch error, error.code: ' + JSON.stringify(releaseErr.code) +
  14. ' error.message: ' + JSON.stringify(releaseErr.message));
  15. }
  16. }).catch((err) => {
  17. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  18. ' error.message: ' + JSON.stringify(err.message));
  19. });
  20. }
  21. }

Caller.onRelease

onRelease(callback: OnReleaseCallback): void;

注册通用组件服务端Stub(桩)断开监听通知。

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

参数:

参数名类型必填说明
callbackOnReleaseCallback返回onRelease回调结果。

示例:

  1. let caller;
  2. export default class MainAbility extends Ability {
  3. onWindowStageCreate(windowStage) {
  4. this.context.startAbilityByCall({
  5. bundleName: 'com.example.myservice',
  6. abilityName: 'MainAbility',
  7. deviceId: ''
  8. }).then((obj) => {
  9. caller = obj;
  10. try {
  11. caller.onRelease((str) => {
  12. console.log(' Caller OnRelease CallBack is called ' + str);
  13. });
  14. } catch (error) {
  15. console.log('Caller.onRelease catch error, error.code: ' + JSON.stringify(error.code) +
  16. ' error.message: ' + JSON.stringify(error.message));
  17. }
  18. }).catch((err) => {
  19. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  20. ' error.message: ' + JSON.stringify(err.message));
  21. });
  22. }
  23. }

Caller.on

on(type: 'release', callback: OnReleaseCallback): void;

注册通用组件服务端Stub(桩)断开监听通知。

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

参数:

参数名类型必填说明
typestring监听releaseCall事件,固定为'release'。
callbackOnReleaseCallback返回onRelease回调结果。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. let caller;
  2. export default class MainAbility extends Ability {
  3. onWindowStageCreate(windowStage) {
  4. this.context.startAbilityByCall({
  5. bundleName: 'com.example.myservice',
  6. abilityName: 'MainAbility',
  7. deviceId: ''
  8. }).then((obj) => {
  9. caller = obj;
  10. try {
  11. caller.on('release', (str) => {
  12. console.log(' Caller OnRelease CallBack is called ' + str);
  13. });
  14. } catch (error) {
  15. console.log('Caller.on catch error, error.code: ' + JSON.stringify(error.code) +
  16. ' error.message: ' + JSON.stringify(error.message));
  17. }
  18. }).catch((err) => {
  19. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  20. ' error.message: ' + JSON.stringify(err.message));
  21. });
  22. }
  23. }

Caller.off

off(type: 'release', callback: OnReleaseCallback): void;

取消注册通用组件服务端Stub(桩)断开监听通知。预留能力,当前暂未支持。

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

参数:

参数名类型必填说明
typestring监听releaseCall事件,固定为'release'。
callbackOnReleaseCallback返回off回调结果。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. let caller;
  2. export default class MainUIAbility extends Ability {
  3. onWindowStageCreate(windowStage) {
  4. this.context.startAbilityByCall({
  5. bundleName: 'com.example.myservice',
  6. abilityName: 'MainUIAbility',
  7. deviceId: ''
  8. }).then((obj) => {
  9. caller = obj;
  10. try {
  11. let onReleaseCallBack = (str) => {
  12. console.log(' Caller OnRelease CallBack is called ' + str);
  13. };
  14. caller.on('release', onReleaseCallBack);
  15. caller.off('release', onReleaseCallBack);
  16. } catch (error) {
  17. console.log('Caller.on or Caller.off catch error, error.code: ' + JSON.stringify(error.code) +
  18. ' error.message: ' + JSON.stringify(error.message));
  19. }
  20. }).catch((err) => {
  21. console.log('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  22. ' error.message: ' + JSON.stringify(err.message));
  23. });
  24. }
  25. }

Caller.off

off(type: 'release'): void;

取消注册通用组件服务端Stub(桩)断开监听通知。预留能力,当前暂未支持。

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

参数:

参数名类型必填说明
typestring监听releaseCall事件,固定为'release'。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. let caller;
  2. export default class MainUIAbility extends Ability {
  3. onWindowStageCreate(windowStage) {
  4. this.context.startAbilityByCall({
  5. bundleName: 'com.example.myservice',
  6. abilityName: 'MainUIAbility',
  7. deviceId: ''
  8. }).then((obj) => {
  9. caller = obj;
  10. try {
  11. let onReleaseCallBack = (str) => {
  12. console.log(' Caller OnRelease CallBack is called ' + str);
  13. };
  14. caller.on('release', onReleaseCallBack);
  15. caller.off('release');
  16. } catch (error) {
  17. console.error('Caller.on or Caller.off catch error, error.code: ' + JSON.stringify(error.code) +
  18. ' error.message: ' + JSON.stringify(error.message));
  19. }
  20. }).catch((err) => {
  21. console.error('Caller GetCaller error, error.code: ' + JSON.stringify(err.code) +
  22. ' error.message: ' + JSON.stringify(err.message));
  23. });
  24. }
  25. }

Callee

通用组件服务端注册和解除客户端caller通知送信的callback接口。

Callee.on

on(method: string, callback: CalleeCallback): void;

通用组件服务端注册消息通知callback。

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

参数:

参数名类型必填说明
methodstring与客户端约定的通知消息字符串。
callbackCalleeCallback一个rpc.MessageSequence类型入参的js通知同步回调函数, 回调函数至少要返回一个空的rpc.Parcelable数据对象, 其他视为函数执行错误。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. class MyMessageAble{
  2. name:''
  3. str:''
  4. num: 1
  5. constructor(name, str) {
  6. this.name = name;
  7. this.str = str;
  8. }
  9. marshalling(messageSequence) {
  10. messageSequence.writeInt(this.num);
  11. messageSequence.writeString(this.str);
  12. console.log('MyMessageAble marshalling num[' + this.num + '] str[' + this.str + ']');
  13. return true;
  14. }
  15. unmarshalling(messageSequence) {
  16. this.num = messageSequence.readInt();
  17. this.str = messageSequence.readString();
  18. console.log('MyMessageAble unmarshalling num[' + this.num + '] str[' + this.str + ']');
  19. return true;
  20. }
  21. };
  22. let method = 'call_Function';
  23. function funcCallBack(pdata) {
  24. console.log('Callee funcCallBack is called ' + pdata);
  25. let msg = new MyMessageAble('test', '');
  26. pdata.readParcelable(msg);
  27. return new MyMessageAble('test1', 'Callee test');
  28. }
  29. export default class MainAbility extends Ability {
  30. onCreate(want, launchParam) {
  31. console.log('Callee onCreate is called');
  32. try {
  33. this.callee.on(method, funcCallBack);
  34. } catch (error) {
  35. console.log('Callee.on catch error, error.code: ' + JSON.stringify(error.code) +
  36. ' error.message: ' + JSON.stringify(error.message));
  37. }
  38. }
  39. }

Callee.off

off(method: string): void;

解除通用组件服务端注册消息通知callback。

系统能力:SystemCapability.UIAbility.UIAbilityRuntime.UIAbilityCore

参数:

参数名类型必填说明
methodstring已注册的通知事件字符串。

错误码:

错误码ID错误信息
401If the input parameter is not valid parameter.
其他ID见元能力子系统错误码 

示例:

  1. let method = 'call_Function';
  2. export default class MainAbility extends Ability {
  3. onCreate(want, launchParam) {
  4. console.log('Callee onCreate is called');
  5. try {
  6. this.callee.off(method);
  7. } catch (error) {
  8. console.log('Callee.off catch error, error.code: ' + JSON.stringify(error.code) +
  9. ' error.message: ' + JSON.stringify(error.message));
  10. }
  11. }
  12. }

OnReleaseCallback

(msg: string): void;

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

名称可读可写类型说明
(msg: string)function调用者注册的侦听器函数接口的原型。

CalleeCallback

(indata: rpc.MessageSequence): rpc.Parcelable;

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

名称可读可写类型说明
(indata: rpc.MessageSequence)rpc.Parcelable被调用方注册的消息侦听器函数接口的原型。
以上内容是否对您有帮助:
在线笔记
App下载
App下载

扫描二维码

下载编程狮App

公众号
微信公众号

编程狮公众号