創(chuàng)建PageAbility
通過DevEco Studio開發(fā)平臺創(chuàng)建PageAbility時(shí),DevEco Studio會在app.js/app.ets中默認(rèn)生成onCreate()和onDestroy()方法,其他方法需要開發(fā)者自行實(shí)現(xiàn)。接口說明參見前述章節(jié),創(chuàng)建PageAbility示例如下:
import featureAbility from '@ohos.ability.featureAbility';
import hilog from '@ohos.hilog';
const TAG: string = 'MainAbility';
const domain: number = 0xFF00;
class MainAbility {
onCreate() {
// 獲取context并調(diào)用相關(guān)方法
let context = featureAbility.getContext();
context.getBundleName((data, bundleName) = > {
hilog.info(domain, TAG, 'ability bundleName:' ,bundleName);
});
hilog.info(domain, TAG, 'Application onCreate');
}
onDestroy() {
hilog.info(domain, TAG, 'Application onDestroy');
}
onShow(): void {
hilog.info(domain, TAG, 'Application onShow');
}
onHide(): void {
hilog.info(domain, TAG, 'Application onHide');
}
onActive(): void {
hilog.info(domain, TAG, 'Application onActive');
}
onInactive(): void {
hilog.info(domain, TAG, 'Application onInactive');
}
onNewWant() {
hilog.info(domain, TAG, 'Application onNewWant');
}
}
export default new MainAbility();
PageAbility創(chuàng)建成功后,其abilities相關(guān)的配置項(xiàng)在config.json中體現(xiàn),一個(gè)名字為EntryAbility的config.json配置文件示例如下:
{
...
"module": {
...
"abilities": [
{
"skills": [
{
"entities": [
"entity.system.home"
],
"actions": [
"action.system.home"
]
}
],
"orientation": "unspecified",
"formsEnabled": false,
"name": ".MainAbility",
"srcLanguage": "ets",
"srcPath": "MainAbility",
"icon": "$media:icon",
"description": "$string:MainAbility_desc",
"label": "$string:MainAbility_label",
"type": "page",
"visible": true,
"launchType": "singleton"
},
...
]
...
}
}
FA模型中,可以通過featureAbility的getContext接口獲取應(yīng)用上下文,進(jìn)而使用上下文提供的能力。
表1 featureAbility接口說明
| 接口名 | 接口描述 |
|---|---|
| getContext() | 獲取應(yīng)用上下文。開發(fā)前請熟悉鴻蒙開發(fā)指導(dǎo)文檔:gitee.com/li-shizhen-skin/harmony-os/blob/master/README.md點(diǎn)擊或者復(fù)制轉(zhuǎn)到。 |

通過getContext獲取應(yīng)用上下文并獲取分布式目錄的示例如下:
import featureAbility from '@ohos.ability.featureAbility';
import fs from '@ohos.file.fs';
import promptAction from '@ohos.promptAction';
import hilog from '@ohos.hilog';
const TAG: string = 'PagePageAbilityFirst';
const domain: number = 0xFF00;
(async (): Promise< void > = > {
let dir: string;
try {
hilog.info(domain, TAG, 'Begin to getOrCreateDistributedDir');
dir = await featureAbility.getContext().getOrCreateDistributedDir();
promptAction.showToast({
message: dir
});
hilog.info(domain, TAG, 'distribute dir is ' + dir);
let fd: number;
let path = dir + '/a.txt';
fd = fs.openSync(path, fs.OpenMode.READ_WRITE).fd;
fs.close(fd);
} catch (error) {
hilog.error(domain, TAG, 'getOrCreateDistributedDir failed with : ' + error);
}
})()
審核編輯 黃宇
聲明:本文內(nèi)容及配圖由入駐作者撰寫或者入駐合作網(wǎng)站授權(quán)轉(zhuǎn)載。文章觀點(diǎn)僅代表作者本人,不代表電子發(fā)燒友網(wǎng)立場。文章及其配圖僅供工程師學(xué)習(xí)之用,如有內(nèi)容侵權(quán)或者其他違規(guī)問題,請聯(lián)系本站處理。
舉報(bào)投訴
-
接口
+關(guān)注
關(guān)注
33文章
9521瀏覽量
157043 -
鴻蒙
+關(guān)注
關(guān)注
60文章
2963瀏覽量
45905
發(fā)布評論請先 登錄
相關(guān)推薦
熱點(diǎn)推薦
Stage模型啟動FA模型PageAbility方法
Stage模型啟動FA模型PageAbility
本小節(jié)介紹Stage模型的兩種應(yīng)用組件如何啟動FA模型的PageAbility組件。
UIAbility啟動PageAbility
發(fā)表于 06-04 06:36
PageAbility切換為UIAbility的方法
PageAbility切換
FA模型中PageAbility對應(yīng)Stage模型中的UIAbility,PageAbility切換為UIAbility的方法如下。
在Stage應(yīng)用中創(chuàng)建
發(fā)表于 06-05 06:07
HarmonyOS應(yīng)用開發(fā)-PageAbility生命周期介
調(diào)用onDestroy方法,開發(fā)者可以在該方法里做一些回收資源、清空緩存等應(yīng)用退出前的準(zhǔn)備工作。onCreate() :Ability第一次啟動創(chuàng)建Ability時(shí)調(diào)用onCreate方法,開發(fā)者可以
發(fā)表于 10-17 11:11
HarmonyOS/OpenHarmony應(yīng)用開發(fā)-PageAbility開發(fā)體驗(yàn)
功能簡介PageAbility是具備ArkUI實(shí)現(xiàn)的Ability,是開發(fā)者具體可見并可以交互的Ability實(shí)例。開發(fā)者通過IDE創(chuàng)建Ability時(shí),IDE會自動
發(fā)表于 12-08 11:03
供鴻蒙應(yīng)用開發(fā)者使用的精美圖表庫控件
該三方開源庫從github fork過來,主要將底層接口調(diào)用的實(shí)現(xiàn)修改成鴻蒙接口的實(shí)現(xiàn),將三方庫鴻蒙化,供開發(fā)鴻蒙應(yīng)用的開發(fā)者使用 Eaze
發(fā)表于 04-01 10:31
?1次下載
鴻蒙開發(fā):【PageAbility組件概述+配置】
PageAbility是包含UI、提供展示UI能力的應(yīng)用組件,主要用于與用戶交互。
鴻蒙開發(fā):【PageAbility的生命周期】
PageAbility生命周期是PageAbility被調(diào)度到INACTIVE、ACTIVE、BACKGROUND等各個(gè)狀態(tài)的統(tǒng)稱。PageAbility生命周期流轉(zhuǎn)及狀態(tài)說明見如下圖1、表1所示。
鴻蒙開發(fā):啟動本地PageAbility
PageAbility相關(guān)的能力通過featureAbility提供,啟動本地Ability通過featureAbility中的startAbility接口實(shí)現(xiàn)。
鴻蒙開發(fā):啟動遠(yuǎn)程PageAbility 僅對系統(tǒng)應(yīng)用開放
啟動遠(yuǎn)程PageAbility同樣通過featureAbility中的startAbility接口實(shí)現(xiàn)。
鴻蒙開發(fā):啟動指定頁面
當(dāng)PageAbility的啟動模式設(shè)置為單例時(shí)(具體設(shè)置方法和典型場景示例見[PageAbility的啟動模式],缺省情況下是單實(shí)例模式),若PageAbility已被拉起,再次啟動PageA
鴻蒙開發(fā)Ability Kit程序框架服務(wù):Stage模型啟動FA模型PageAbility
本小節(jié)介紹Stage模型的兩種應(yīng)用組件如何啟動FA模型的PageAbility組件。
鴻蒙開發(fā)Ability Kit程序框架服務(wù):PageAbility切換 組件切換
FA模型中PageAbility對應(yīng)Stage模型中的UIAbility,PageAbility切換為UIAbility的方法如下。
鴻蒙開發(fā):創(chuàng)建PageAbility
評論