HarmonyOS4.0系统性深入开发22创建PageAbility

本文详细介绍了在DevEcoStudio中创建和管理PageAbility的过程,包括生命周期回调函数、使用featureAbility接口获取和操作应用上下文、启动与停止Ability,以及权限申请和Ability的可见性设置。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

创建PageAbility

开发者需要重写app.js/app.ets中的生命周期回调函数,开发者通过DevEco Studio开发平台创建PageAbility时,DevEco Studio会在app.js/app.ets中默认生成onCreate()和onDestroy()方法,其他方法需要开发者自行实现。接口说明参见前述章节,创建PageAbility示例如下:

export default {
   
  onCreate() {
   
    console.info('Application onCreate')
  },
  onDestroy() {
   
    console.info('Application onDestroy')
  },
  onShow() {
   
    console.info('Application onShow')
  },
  onHide() {
   
    console.info('Application onHide')
  },
  onActive() {
   
    console.info('Application onActive')
  },
  onInactive() {
   
    console.info('Application onInactive')
  },
  onNewWant() {
   
    console.info('Application onNewWant')
  },
}

PageAbility创建成功后,其abilities相关的配置项在config.json中体现,一个名字为MainAbility的config.json配置文件示例如下:

{
   
  "abilities": [
    {
   
      "skills": [
        {
   
          "entities": [
            "entity.system.home"
          ],
          "actions": [
            "action.system.home"
          ]
        }
      ],
      "orientation": "unspecified",
      "visible": true,
      "srcPath": "MainAbility",
      "name": ".MainAbility",
      "srcLanguage": "ets",
      "icon": "$media:icon",
      "description": "$string:MainAbility_desc",
      "formsEnabled": false,
      "label": "$string:MainAbility_label",
      "type": "page",
      "launchType": "singleton"
    }
  ]
}

FA模型中,可以通过featureAbility的getContext接口获取应用上下文,进而使用上下文提供的能力。

表1 featureAbility接口说明

接口名 接口描述
getContext() 获取应用上下文。

通过getContext获取应用上下文并获取分布式目录的示例如下:

import featureAbility from '@ohos.ability.featureAbility'
import fileIo from '@ohos.fileio'

(async () 
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值