UIAbility組件基本用法
UIAbility組件的基本用法包括:指定UIAbility的啟動(dòng)頁(yè)面以及獲取UIAbility的上下文[UIAbilityContext]。
指定UIAbility的啟動(dòng)頁(yè)面
應(yīng)用中的UIAbility在啟動(dòng)過(guò)程中,需要指定啟動(dòng)頁(yè)面,否則應(yīng)用啟動(dòng)后會(huì)因?yàn)闆](méi)有默認(rèn)加載頁(yè)面而導(dǎo)致白屏。可以在UIAbility的onWindowStageCreate()
生命周期回調(diào)中,通過(guò)[WindowStage]對(duì)象的loadContent()
方法設(shè)置啟動(dòng)頁(yè)面。
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) = > {
// ...
});
}
// ...
}
說(shuō)明: 在DevEco Studio中創(chuàng)建的UIAbility中,該UIAbility實(shí)例默認(rèn)會(huì)加載Index頁(yè)面,根據(jù)需要將Index頁(yè)面路徑替換為需要的頁(yè)面路徑即可。 開(kāi)發(fā)前請(qǐng)熟悉鴻蒙開(kāi)發(fā)指導(dǎo)文檔 :[
gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md
]
獲取UIAbility的上下文信息
UIAbility類擁有自身的上下文信息,該信息為[UIAbilityContext]類的實(shí)例,[UIAbilityContext]類擁有abilityInfo、currentHapModuleInfo等屬性。通過(guò)UIAbilityContext可以獲取UIAbility的相關(guān)配置信息,如包代碼路徑、Bundle名稱、Ability名稱和應(yīng)用程序需要的環(huán)境狀態(tài)等屬性信息,以及可以獲取操作UIAbility實(shí)例的方法(如startAbility()
、connectServiceExtensionAbility()
、terminateSelf()
等)。 如果需要在頁(yè)面中獲得當(dāng)前Ability的Context,可調(diào)用[getContext]接口獲取當(dāng)前頁(yè)面關(guān)聯(lián)的UIAbilityContext或ExtensionContext。
在UIAbility中可以通過(guò)
this.context
獲取UIAbility實(shí)例的上下文信息。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實(shí)例的上下文 let context = this.context; // ... } }
在頁(yè)面中獲取UIAbility實(shí)例的上下文信息,包括導(dǎo)入依賴資源context模塊和在組件中定義一個(gè)context變量?jī)蓚€(gè)部分。
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); } // 頁(yè)面展示 build() { // ... } }
也可以在導(dǎo)入依賴資源context模塊后,在具體使用[UIAbilityContext]前進(jìn)行變量定義。
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); } // 頁(yè)面展示 build() { // ... } }
審核編輯 黃宇
-
框架
+關(guān)注
關(guān)注
0文章
404瀏覽量
17860 -
組件
+關(guān)注
關(guān)注
1文章
532瀏覽量
18377 -
鴻蒙
+關(guān)注
關(guān)注
59文章
2588瀏覽量
43929
發(fā)布評(píng)論請(qǐng)先 登錄
鴻蒙Ability Kit(程序框架服務(wù))【UIAbility組件生命周期】

鴻蒙Ability Kit(程序框架服務(wù))【UIExtensionAbility】

鴻蒙應(yīng)用模型:【Ability Kit】簡(jiǎn)介

鴻蒙Ability Kit(程序框架服務(wù))【UIAbility組件生命周期】實(shí)例

鴻蒙Ability Kit(程序框架服務(wù))【UIAbility組件啟動(dòng)模式】

鴻蒙Ability Kit(程序框架服務(wù))【UIAbility組件與UI的數(shù)據(jù)同步】

鴻蒙Ability Kit(程序框架服務(wù))【UIAbility組件間交互(設(shè)備內(nèi))】

鴻蒙Ability Kit(程序框架服務(wù))【UIAbility內(nèi)和UIAbility間頁(yè)面的跳轉(zhuǎn)】

鴻蒙Ability Kit(程序框架服務(wù))【ExtensionAbility組件】

鴻蒙Ability Kit(程序框架服務(wù))【組件啟動(dòng)規(guī)則(Stage模型)】

鴻蒙開(kāi)發(fā)Ability Kit程序框架服務(wù):任務(wù)管理

鴻蒙開(kāi)發(fā)Ability Kit程序框架服務(wù):FA模型與Stage模型應(yīng)用組件互通綜述

鴻蒙開(kāi)發(fā)Ability Kit程序框架服務(wù):FA模型啟動(dòng)Stage模型UIAbility

評(píng)論