HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第56天,PageAbility的启动模式,创建,启动,停止。

发布于 1周前 作者 eggper 来自 鸿蒙OS

HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第56天,PageAbility的启动模式,创建,启动,停止。 1、PageAbility的启动模式

启动模式对应PageAbility被启动时的行为,支持单实例模式、标准模式两种启动模式。

表1 PageAbility的启动模式

启动模式 描述 说明
singleton 单实例模式 每次调用startAbility方法时,如果应用进程中该类型的Ability实例已经存在,则复用已有的实例,系统中只存在唯一一个实例。表现为在最近任务列表中只有一个Ability实例。
典型场景:当用户打开视频播放应用并观看视频,回到桌面后,再次打开视频播放应用,应用仍为回到桌面之前正在观看的视频。
standard 标准模式 缺省启动模式。每次调用startAbility方法时,都会在应用进程中创建一个新的Ability实例。表现为在最近任务列表中可以看到有多个该类型的Ability实例。
典型场景:当用户打开文档应用,选择新建文档的时候,每次点击新建文档,都会创建一个新的文档任务,在最近任务列表中可以看到多个新建的文档任务。

应用开发者可在config.json配置文件中通过“launchType”配置启动模式。示例如下:

{
  "module": {
    // ...
    "abilities": [
      {
        // singleton: 单实例模式
        // standard: 标准模式
        "launchType": "standard",
        // ...
      }
    ]
  }
}

启动PageAbility时,对于标准启动模式(多实例启动模式)以及单实例启动模式首次启动,PageAbility生命周期回调均会被触发。单实例非首次启动时不会再触发onCreate()接口,而是触发onNewWant(),onNewWant()的说明如下表2所示。

表2 单实例启动模式特有的回调函数说明

接口名 接口描述
onNewWant(want: Want) 单实例启动模式,PageAbility非首次启动时调用onNewWant方法,开发者可以在该方法中获取want,进而根据want做进一步处理。例如,单实例PageAbility迁移场景,指定页面拉起PageAbility场景。

2、创建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 () => {
  let dir: string
  try {
    console.info('Begin to getOrCreateDistributedDir')
    dir = await featureAbility.getContext().getOrCreateDistributedDir()
    console.info('distribute dir is ' + dir)
  } catch (error) {
    console.error('getOrCreateDistributedDir failed with ' + error)
  }

  let fd: number;
  let path = dir + "/a.txt";
  fd = fileIo.openSync(path, 0o2 | 0o100, 0o666);
  fileIo.close(fd);
})()

3、启动本地PageAbility

PageAbility相关的能力通过featureAbility提供,启动本地Ability通过featureAbility中的startAbility接口实现。

表1 featureAbility接口说明

接口名 接口描述
startAbility(parameter: StartAbilityParameter) 启动Ability。
startAbilityForResult(parameter: StartAbilityParameter) 启动Ability,并在该Ability被销毁时返回执行结果。

如下示例通过startAbility显式启动PageAbility。启动Ability的参数包含want,关于want的说明详见对象间信息传递载体Want,相应的,

隐式启动与显式启动也不在此赘述。

import featureAbility from '@ohos.ability.featureAbility'

(async () => {
  try {
    console.info('Begin to start ability')
    let param = {
      want: {
        bundleName: "com.example.myapplication",
        moduleName: "entry",
        abilityName: "com.example.myapplication.MainAbility"
      }
    }
    await featureAbility.startAbility(param)
    console.info(`Start ability succeed`)
  } 
  catch (error) {
    console.error('Start ability failed with ' + error)
  }
})()

4、停止PageAbility

停止PageAbility通过featureAbility中的terminateSelf接口实现。

表1 featureAbility接口说明

接口名 接口描述
terminateSelf() 停止Ability。
terminateSelfWithResult(parameter: AbilityResult) 设置该PageAbility停止时返回给调用者的结果及数据并停止Ability。

如下示例展示了停止Ability的方法。

import featureAbility from '@ohos.ability.featureAbility'

(async () => {
  try {
    console.info('Begin to terminateSelf')
    await featureAbility.terminateSelf()
    console.info('terminateSelf succeed')
  } 
  catch (error) {
    console.error('terminateSelf failed with ' + error)
  }
})()

更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第56天,PageAbility的启动模式,创建,启动,停止。的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html

2 回复

在HarmonyOS鸿蒙Next中,PageAbility是应用的基本组成单元之一,负责管理页面的生命周期和用户交互。

  1. 启动模式:PageAbility支持多种启动模式,包括Standard、SingleTop、SingleTask和SingleInstance。Standard模式每次启动都会创建一个新的实例;SingleTop模式如果目标PageAbility已经在栈顶,则不会创建新实例;SingleTask模式确保栈中只有一个实例;SingleInstance模式则确保整个系统中只有一个实例。

  2. 创建:PageAbility的创建通过onCreate方法实现,开发者可以在此方法中初始化页面所需的资源和数据。

  3. 启动:PageAbility的启动通过startAbility方法实现,可以传递参数给目标PageAbility。启动后,目标PageAbility的onStart方法会被调用。

  4. 停止:PageAbility的停止通过onStop方法实现,开发者可以在此方法中释放资源和保存数据。当PageAbility不再可见时,onStop方法会被调用。

这些操作共同管理PageAbility的生命周期,确保应用的高效运行和资源管理。

更多关于HarmonyOS 鸿蒙Next ArkTS语言教程入门学习第56天,PageAbility的启动模式,创建,启动,停止。的实战系列教程也可以访问 https://www.itying.com/category-93-b0.html


在HarmonyOS中,PageAbility是应用的基本组件之一,负责页面的展示和交互。PageAbility的启动模式包括standardsingleTopsingleTasksingleInstance,分别对应不同的启动行为。创建PageAbility时,需在config.json中声明,并实现onStartonActive等生命周期方法。启动PageAbility可通过startAbility方法,停止则调用terminateSelf。合理使用启动模式能优化应用性能和用户体验。

回到顶部
AI 助手
你好,我是IT营的 AI 助手
您可以尝试点击下方的快捷入口开启体验!