1# 管理ArkTS卡片生命周期 2<!--Kit: Form Kit--> 3<!--Subsystem: Ability--> 4<!--Owner: @cx983299475--> 5<!--Designer: @xueyulong--> 6<!--Tester: @chenmingze--> 7<!--Adviser: @Brilliantry_Rui--> 8 9创建ArkTS卡片,需实现[FormExtensionAbility](../reference/apis-form-kit/js-apis-app-form-formExtensionAbility.md)生命周期接口。 10 111. 在EntryFormAbility.ets中,导入相关模块。 12 ```ts 13 import { formBindingData, FormExtensionAbility, formInfo, formProvider } from '@kit.FormKit'; 14 import { Configuration, Want } from '@kit.AbilityKit'; 15 import { BusinessError } from '@kit.BasicServicesKit'; 16 import { hilog } from '@kit.PerformanceAnalysisKit'; 17 ``` 18 192. 在EntryFormAbility.ets中,实现[FormExtensionAbility](../reference/apis-form-kit/js-apis-app-form-formExtensionAbility.md)生命周期接口,其中在onAddForm的入参[want](../reference/apis-ability-kit/js-apis-app-ability-want.md)中可以通过[FormParam](../reference/apis-form-kit/js-apis-app-form-formInfo.md#formparam)取出卡片的相关信息。 20 ```ts 21 const TAG: string = 'EntryFormAbility'; 22 const DOMAIN_NUMBER: number = 0xFF00; 23 24 export default class EntryFormAbility extends FormExtensionAbility { 25 onAddForm(want: Want): formBindingData.FormBindingData { 26 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onAddForm'); 27 hilog.info(DOMAIN_NUMBER, TAG, want.parameters?.[formInfo.FormParam.NAME_KEY] as string); 28 29 // ... 30 // 卡片使用方创建卡片时触发,提供方需要返回卡片数据绑定类 31 let obj: Record<string, string> = { 32 'title': 'titleOnAddForm', 33 'detail': 'detailOnAddForm' 34 }; 35 let formData: formBindingData.FormBindingData = formBindingData.createFormBindingData(obj); 36 return formData; 37 } 38 39 onCastToNormalForm(formId: string): void { 40 // 当前卡片使用方不会涉及该场景,无需实现该回调函数 41 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onCastToNormalForm'); 42 } 43 44 onUpdateForm(formId: string): void { 45 // 若卡片支持定时更新/定点更新/卡片使用方主动请求更新功能,则提供方需要重写该方法以支持数据更新 46 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onUpdateForm'); 47 let obj: Record<string, string> = { 48 'title': 'titleOnUpdateForm', 49 'detail': 'detailOnUpdateForm' 50 }; 51 let formData: formBindingData.FormBindingData = formBindingData.createFormBindingData(obj); 52 formProvider.updateForm(formId, formData).catch((error: BusinessError) => { 53 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] updateForm, error:' + JSON.stringify(error)); 54 }); 55 } 56 57 onChangeFormVisibility(newStatus: Record<string, number>): void { 58 // 卡片使用方发起可见或者不可见通知触发,提供方需要做相应的处理,仅系统应用生效 59 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onChangeFormVisibility'); 60 } 61 62 onFormEvent(formId: string, message: string): void { 63 // 若卡片支持触发事件,则需要重写该方法并实现对事件的触发 64 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onFormEvent'); 65 // ... 66 } 67 68 onRemoveForm(formId: string): void { 69 // 删除卡片实例数据 70 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onRemoveForm'); 71 // 删除之前持久化的卡片实例数据 72 // 此接口请根据实际情况实现,具体请参考:FormExtAbility Stage模型卡片实例 73 } 74 75 onConfigurationUpdate(config: Configuration) { 76 // 当前formExtensionAbility存活时更新系统配置信息时触发的回调。 77 // 需注意:formExtensionAbility创建后10秒内无操作将会被清理。 78 hilog.info(DOMAIN_NUMBER, TAG, '[EntryFormAbility] onConfigurationUpdate:' + JSON.stringify(config)); 79 } 80 81 onAcquireFormState(want: Want) { 82 // 卡片提供方接收查询卡片状态通知接口,默认返回卡片初始状态。 83 return formInfo.FormState.READY; 84 } 85 } 86 ``` 87 88> **说明:** 89> 90> FormExtensionAbility进程不能常驻后台,即在卡片生命周期回调函数中无法处理长时间的任务,在生命周期调度完成后会继续存在10秒,如10秒内没有新的生命周期回调触发则进程自动退出。针对可能需要10秒以上才能完成的业务逻辑,建议[拉起主应用](arkts-ui-widget-event-overview.md)进行处理,处理完成后使用[updateForm](../reference/apis-form-kit/js-apis-app-form-formProvider.md#formproviderupdateform)通知卡片进行刷新。 91