UIAbility組件基本用法
UIAbility組件的基本用法包括:指定UIAbility的啟動頁面以及獲取UIAbility的上下文[UIAbilityContext]。
指定UIAbility的啟動頁面
應用中的UIAbility在啟動過程中,需要指定啟動頁面,否則應用啟動后會因為沒有默認加載頁面而導致白屏??梢栽赨IAbility的onWindowStageCreate()生命周期回調(diào)中,通過[WindowStage]對象的loadContent()方法設置啟動頁面。
import UIAbility from '@ohos.app.ability.UIAbility';
import window from '@ohos.window';
export default class EntryAbility extends UIAbility {
onWindowStageCreate(windowStage: window.WindowStage): void {
// Main window is created, set main page for this ability
windowStage.loadContent('pages/Index', (err, data) = > {
// ...
});
}
// ...
}
說明: 在DevEco Studio中創(chuàng)建的UIAbility中,該UIAbility實例默認會加載Index頁面,根據(jù)需要將Index頁面路徑替換為需要的頁面路徑即可。 開發(fā)前請熟悉鴻蒙開發(fā)指導文檔 :[
gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md]

獲取UIAbility的上下文信息
UIAbility類擁有自身的上下文信息,該信息為[UIAbilityContext]類的實例,[UIAbilityContext]類擁有abilityInfo、currentHapModuleInfo等屬性。通過UIAbilityContext可以獲取UIAbility的相關配置信息,如包代碼路徑、Bundle名稱、Ability名稱和應用程序需要的環(huán)境狀態(tài)等屬性信息,以及可以獲取操作UIAbility實例的方法(如startAbility()、connectServiceExtensionAbility()、terminateSelf()等)。 如果需要在頁面中獲得當前Ability的Context,可調(diào)用[getContext]接口獲取當前頁面關聯(lián)的UIAbilityContext或ExtensionContext。
在UIAbility中可以通過
this.context獲取UIAbility實例的上下文信息。import UIAbility from '@ohos.app.ability.UIAbility'; import AbilityConstant from '@ohos.app.ability.AbilityConstant'; import Want from '@ohos.app.ability.Want'; export default class EntryAbility extends UIAbility { onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void { // 獲取UIAbility實例的上下文 let context = this.context; // ... } }在頁面中獲取UIAbility實例的上下文信息,包括導入依賴資源context模塊和在組件中定義一個context變量兩個部分。
import common from '@ohos.app.ability.common'; import Want from '@ohos.app.ability.Want'; @Entry @Component struct Page_EventHub { private context = getContext(this) as common.UIAbilityContext; startAbilityTest() : void { let want: Want = { // Want參數(shù)信息 }; this.context.startAbility(want); } // 頁面展示 build() { // ... } }也可以在導入依賴資源context模塊后,在具體使用[UIAbilityContext]前進行變量定義。
import common from '@ohos.app.ability.common'; import Want from '@ohos.app.ability.Want'; @Entry @Component struct Page_UIAbilityComponentsBasicUsage { startAbilityTest(): void { let context = getContext(this) as common.UIAbilityContext; let want: Want = { // Want參數(shù)信息 }; context.startAbility(want); } // 頁面展示 build() { // ... } }
審核編輯 黃宇
-
框架
+關注
關注
0文章
404瀏覽量
18309 -
組件
+關注
關注
1文章
550瀏覽量
18914 -
鴻蒙
+關注
關注
60文章
2839瀏覽量
45334
發(fā)布評論請先 登錄
鴻蒙Ability Kit(程序框架服務)【UIAbility組件生命周期】
鴻蒙Ability Kit(程序框架服務)【UIExtensionAbility】
鴻蒙Ability Kit(程序框架服務)【UIAbility組件生命周期】實例
鴻蒙Ability Kit(程序框架服務)【UIAbility組件啟動模式】
鴻蒙Ability Kit(程序框架服務)【UIAbility組件與UI的數(shù)據(jù)同步】
鴻蒙Ability Kit(程序框架服務)【UIAbility組件間交互(設備內(nèi))】
鴻蒙Ability Kit(程序框架服務)【UIAbility內(nèi)和UIAbility間頁面的跳轉(zhuǎn)】
鴻蒙Ability Kit(程序框架服務)【ExtensionAbility組件】
鴻蒙開發(fā)Ability Kit程序框架服務:任務管理
鴻蒙開發(fā)Ability Kit程序框架服務:FA模型與Stage模型應用組件互通綜述
【HarmonyOS 5】鴻蒙中的UIAbility詳解(二)

鴻蒙Ability Kit(程序框架服務)【UIAbility組件基本用法】
評論