Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Docs
提交
43e31630
D
Docs
项目概览
OpenHarmony
/
Docs
1 年多 前同步成功
通知
159
Star
292
Fork
28
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
D
Docs
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
43e31630
编写于
5月 13, 2022
作者:
D
dingyao
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
提交applicationContext的相关接口描述
Signed-off-by:
N
dingyao
<
dingyao5@huawei.com
>
上级
eaa9e07a
变更
6
隐藏空白更改
内联
并排
Showing
6 changed file
with
304 addition
and
18 deletion
+304
-18
zh-cn/application-dev/ability/context-userguide.md
zh-cn/application-dev/ability/context-userguide.md
+71
-9
zh-cn/application-dev/ability/figures/contextIntroduction.png
...n/application-dev/ability/figures/contextIntroduction.png
+0
-0
zh-cn/application-dev/reference/apis/js-apis-application-ability.md
...ication-dev/reference/apis/js-apis-application-ability.md
+2
-2
zh-cn/application-dev/reference/apis/js-apis-application-abilityLifecycleCallback.md
...ence/apis/js-apis-application-abilityLifecycleCallback.md
+153
-0
zh-cn/application-dev/reference/apis/js-apis-application-applicationContext.md
.../reference/apis/js-apis-application-applicationContext.md
+71
-0
zh-cn/application-dev/reference/apis/js-apis-application-context.md
...ication-dev/reference/apis/js-apis-application-context.md
+7
-7
未找到文件。
zh-cn/application-dev/ability/context-userguide.md
浏览文件 @
43e31630
...
@@ -11,7 +11,7 @@
...
@@ -11,7 +11,7 @@
**FA模型**
只有app/Context中的方法属于FA模型对应的Context。该模式下,应用级别的Context和Ability级别的Context都是该类型的实例,如果在应用级别的Context里面调用了Ability级别的方法,会产生错误。所以开发者需要注意context实例所代表的实际含义。
**FA模型**
只有app/Context中的方法属于FA模型对应的Context。该模式下,应用级别的Context和Ability级别的Context都是该类型的实例,如果在应用级别的Context里面调用了Ability级别的方法,会产生错误。所以开发者需要注意context实例所代表的实际含义。
**Stage模型**
除了app/Context之外的Context都属于Stage模型,分别有application/Context、application/A
bilityStageContext、application/ExtensionContext、application/AbilityContext、application/FormExtensionContext和application/ServiceExtensionContext六
种Context。这些Context的介绍及使用方式将会在
[
Stage模型和Context详细介绍
](
#stage模型和context详细介绍
)
种进行说明。
**Stage模型**
除了app/Context之外的Context都属于Stage模型,分别有application/Context、application/A
pplicationContext、application/AbilityStageContext、application/ExtensionContext、application/AbilityContext、application/FormExtensionContext和application/ServiceExtensionContext七
种Context。这些Context的介绍及使用方式将会在
[
Stage模型和Context详细介绍
](
#stage模型和context详细介绍
)
种进行说明。
![
contextIntroduction
](
figures/contextIntroduction.png
)
![
contextIntroduction
](
figures/contextIntroduction.png
)
...
@@ -55,13 +55,13 @@ export default {
...
@@ -55,13 +55,13 @@ export default {
## Stage模型和Context详细介绍
## Stage模型和Context详细介绍
Stage模型有
6
大Context:
Stage模型有
7
大Context:
### application/Context
### application/Context
**概述**
**概述**
application/Context类型的Context是基类Context,里面提供了应用的一些基础信息:resourceManager、applicationInfo、cacheDir等,还有应用的一些基本方法:createBundleContext、switchArea等。
应用级别的Context也是application/Context这种类型。
application/Context类型的Context是基类Context,里面提供了应用的一些基础信息:resourceManager、applicationInfo、cacheDir等,还有应用的一些基本方法:createBundleContext、switchArea等。
**获取方法**
**获取方法**
...
@@ -89,15 +89,77 @@ export default class MainAbility extends Ability {
...
@@ -89,15 +89,77 @@ export default class MainAbility extends Ability {
https://gitee.com/openharmony/interface_sdk-js/blob/master/api/application/Context.d.ts
https://gitee.com/openharmony/interface_sdk-js/blob/master/api/application/Context.d.ts
### application/ApplicationContext
**概述**
application/ApplicationContext是应用级别的Context。和基类Context相比,应用级别的Context中提供了监听进程内组件的生命周期的能力,包括registerAbilityLifecycleCallback和unregisterAbilityLifecycleCallback两种方法。
**获取方法**
在Ability中通过context.getApplicationContext()方法获取。
**示例**
```
javascript
import
AbilityStage
from
"
@ohos.application.AbilityStage
"
;
var
lifecycleid
;
export
default
class
MyAbilityStage
extends
AbilityStage
{
onCreate
()
{
console
.
log
(
"
MyAbilityStage onCreate
"
)
let
AbilityLifecycleCallback
=
{
onAbilityCreate
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityCreate ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityWindowStageCreate
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityWindowStageCreate ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityWindowStageDestroy
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityWindowStageDestroy ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityDestroy
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityDestroy ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityForeground
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityForeground ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityBackground
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityBackground ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityContinue
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityContinue ability:
"
+
JSON
.
stringify
(
ability
));
}
}
// 1.通过context属性获取applicationContext
let
applicationContext
=
this
.
context
.
getApplicationContext
();
// 2.通过applicationContext注册监听应用内生命周期
lifecycleid
=
applicationContext
.
registerAbilityLifecycleCallback
(
AbilityLifecycleCallback
);
console
.
log
(
"
registerAbilityLifecycleCallback number:
"
+
JSON
.
stringify
(
lifecycleid
));
}
onDestroy
()
{
let
applicationContext
=
this
.
context
.
getApplicationContext
();
applicationContext
.
unregisterAbilityLifecycleCallback
(
lifecycleid
,
(
error
,
data
)
=>
{
console
.
log
(
"
unregisterAbilityLifecycleCallback success, err:
"
+
JSON
.
stringify
(
error
));
});
}
}
```
**d.ts声明**
https://gitee.com/openharmony/interface_sdk-js/blob/master/api/application/ApplicationContext.d.ts
### application/AbilityStageContext
### application/AbilityStageContext
**概述**
**概述**
application/AbilityStageContext是Hap包级别的Context。和基类Context相比,Hap包级别的Context中多了HapModuleInfo和Configuration两个信息。
application/AbilityStageContext是Hap包级别的Context。和基类Context相比,Hap包级别的Context中多了HapModuleInfo和Configuration两个信息。
**获取方法**
**获取方法**
可以直接在AbilityStage中通过context属性
拿到
。
可以直接在AbilityStage中通过context属性
获取
。
**示例**
**示例**
...
@@ -116,7 +178,7 @@ export default class MyAbilityStage extends AbilityStage {
...
@@ -116,7 +178,7 @@ export default class MyAbilityStage extends AbilityStage {
### application/AbilityContext
### application/AbilityContext
**概述**
**概述**
Stage模型下,每个Ability中都包含了一个Context属性。
Stage模型下,每个Ability中都包含了一个Context属性。
...
@@ -124,7 +186,7 @@ export default class MyAbilityStage extends AbilityStage {
...
@@ -124,7 +186,7 @@ export default class MyAbilityStage extends AbilityStage {
**获取方法**
**获取方法**
在Ability中通过context属性
拿到
。
在Ability中通过context属性
获取
。
**示例**
**示例**
...
@@ -158,7 +220,7 @@ export default class MainAbility extends Ability {
...
@@ -158,7 +220,7 @@ export default class MainAbility extends Ability {
### application/ExtensionContext
### application/ExtensionContext
**概述**
**概述**
和FA模型不同的是,Stage模型把Service从Ability中剥离出来,单独定义了一组通用扩展类Extension用来处理等同的功能。Extension是一个基类,不承担具体业务功能。业务方根据自己的需要去扩展对应的Extension,例如:ServiceAbility扩展为了ServiceExtensionAbility,卡片扩展为了FormExtension。
和FA模型不同的是,Stage模型把Service从Ability中剥离出来,单独定义了一组通用扩展类Extension用来处理等同的功能。Extension是一个基类,不承担具体业务功能。业务方根据自己的需要去扩展对应的Extension,例如:ServiceAbility扩展为了ServiceExtensionAbility,卡片扩展为了FormExtension。
...
@@ -174,7 +236,7 @@ export default class MainAbility extends Ability {
...
@@ -174,7 +236,7 @@ export default class MainAbility extends Ability {
### application/ServiceExtensionContext
### application/ServiceExtensionContext
**概述**
**概述**
ServiceExtensionAbility类似于FA模型的ServiceAbility,里面只有生命周期回调相关的处理。
ServiceExtensionAbility类似于FA模型的ServiceAbility,里面只有生命周期回调相关的处理。
...
...
zh-cn/application-dev/ability/figures/contextIntroduction.png
查看替换文件 @
eaa9e07a
浏览文件 @
43e31630
55.4 KB
|
W:
|
H:
51.1 KB
|
W:
|
H:
2-up
Swipe
Onion skin
zh-cn/application-dev/reference/apis/js-apis-application-ability.md
浏览文件 @
43e31630
...
@@ -143,7 +143,7 @@ Ability生命周期回调,在销毁时回调,执行资源清理等操作。
...
@@ -143,7 +143,7 @@ Ability生命周期回调,在销毁时回调,执行资源清理等操作。
onForeground(): void;
onForeground(): void;
Ability生命周期回调,当应用
处于
前台时触发。
Ability生命周期回调,当应用
从后台转到
前台时触发。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
...
@@ -162,7 +162,7 @@ Ability生命周期回调,当应用处于前台时触发。
...
@@ -162,7 +162,7 @@ Ability生命周期回调,当应用处于前台时触发。
onBackground(): void;
onBackground(): void;
Ability生命周期回调,当应用
处于
后台时触发。
Ability生命周期回调,当应用
从前台转到
后台时触发。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
...
...
zh-cn/application-dev/reference/apis/js-apis-application-abilityLifecycleCallback.md
0 → 100644
浏览文件 @
43e31630
# AbilityLifecycleCallback
> ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
> 本模块首批接口从API version 9 开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
应用上下文ApplicationContext的生命周期监听方法的回调类,里面提供了onAbilityCreate、onAbilityWindowStageCreate、onAbilityWindowStageDestroy等方法。
## AbilityLifecycleCallback.onAbilityCreate
onAbilityCreate(ability: Ability): void;
注册监听应用上下文的生命周期后,在ability创建时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityWindowStageCreate
onAbilityWindowStageCreate(ability: Ability): void;
注册监听应用上下文的生命周期后,在windowStage创建时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityWindowStageDestroy
onAbilityWindowStageDestroy(ability: Ability): void;
注册监听应用上下文的生命周期后,在windowStage销毁时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityDestroy
onAbilityDestroy(ability: Ability): void;
注册监听应用上下文的生命周期后,在ability销毁时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityForeground
onAbilityForeground(ability: Ability): void;
注册监听应用上下文的生命周期后,在ability的状态从后台转到前台时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityBackground
onAbilityBackground(ability: Ability): void;
注册监听应用上下文的生命周期后,在ability的状态从前台转到后台时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
## AbilityLifecycleCallback.onAbilityContinue
onAbilityContinue(ability: Ability): void;
注册监听应用上下文的生命周期后,在ability迁移时触发回调。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.AbilityCore
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| -------- | -------- | -------- | -------- |
| ability |
[
Ability
](
js-apis-application-ability.md#Ability
)
| 是 | 当前Ability对象 |
**示例:**
```
js
import
AbilityStage
from
"
@ohos.application.AbilityStage
"
;
export
default
class
MyAbilityStage
extends
AbilityStage
{
onCreate
()
{
console
.
log
(
"
MyAbilityStage onCreate
"
)
let
AbilityLifecycleCallback
=
{
onAbilityCreate
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityCreate ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityWindowStageCreate
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityWindowStageCreate ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityWindowStageDestroy
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityWindowStageDestroy ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityDestroy
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityDestroy ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityForeground
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityForeground ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityBackground
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityBackground ability:
"
+
JSON
.
stringify
(
ability
));
},
onAbilityContinue
(
ability
){
console
.
log
(
"
AbilityLifecycleCallback onAbilityContinue ability:
"
+
JSON
.
stringify
(
ability
));
}
}
// 1.通过context属性获取applicationContext
let
applicationContext
=
this
.
context
.
getApplicationContext
();
// 2.通过applicationContext注册监听应用内生命周期
let
lifecycleid
=
applicationContext
.
registerAbilityLifecycleCallback
(
AbilityLifecycleCallback
);
console
.
log
(
"
registerAbilityLifecycleCallback number:
"
+
JSON
.
stringify
(
lifecycleid
));
}
}
```
\ No newline at end of file
zh-cn/application-dev/reference/apis/js-apis-application-applicationContext.md
0 → 100644
浏览文件 @
43e31630
# ApplicationContext
> ![icon-note.gif](public_sys-resources/icon-note.gif) **说明:**
> 本模块首批接口从API version 9开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。
提供开发者应用级别的的上下文,提供注册及取消注册应用内组件生命周期的监听接口。
## 使用说明
在使用ApplicationContext的功能前,需要通过context的实例获取。
```
js
let
applicationContext
=
this
.
context
.
getApplicationContext
();
```
## ApplicationContext.registerAbilityLifecycleCallback
registerAbilityLifecycleCallback(callback: AbilityLifecycleCallback):
**number**
;
注册监听应用内生命周期
**系统能力**
:SystemCapability.Ability.AbilityRuntime.Core
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------------------------ | -------- | ---- | ------------------------------ |
|
[
AbilityLifecycleCallback
](
js-apis-application-abilityLifecycleCallback.md
)
| callback | 是 | 回调方法,返回注册监听事件的id |
**返回值:**
| 类型 | 说明 |
| ------ | ------------------------------ |
| number | 返回的此次注册监听生命周期的id(每次注册该id会自增+1,当超过监听上限数量2^63-1时,返回-1)|
**示例:**
```
js
let
applicationContext
=
this
.
context
.
getApplicationContext
();
console
.
log
(
"
stage applicationContext:
"
+
JSON
.
stringify
(
applicationContext
));
let
lifecycleid
=
applicationContext
.
registerAbilityLifecycleCallback
(
AbilityLifecycleCallback
);
console
.
log
(
"
registerAbilityLifecycleCallback number:
"
+
JSON
.
stringify
(
lifecycleid
));
```
## ApplicationContext.unregisterAbilityLifecycleCallback
unregisterAbilityLifecycleCallback(callbackId:
**number**
, callback: AsyncCallback
<
**void**
>
):
**void**
;
取消监听应用内生命周期
**系统能力**
:SystemCapability.Ability.AbilityRuntime.Core
**参数:**
| 参数名 | 类型 | 必填 | 说明 |
| ------------- | -------- | ---- | -------------------------- |
| callbackId | number | 是 | 注册监听应用内生命周期的id |
| AsyncCallback | callback | 是 | 回调方法 |
**示例:**
```
js
let
applicationContext
=
this
.
context
.
getApplicationContext
();
console
.
log
(
"
stage applicationContext:
"
+
JSON
.
stringify
(
applicationContext
));
applicationContext
.
unregisterAbilityLifecycleCallback
(
lifecycleid
,
(
error
,
data
)
=>
{
console
.
log
(
"
unregisterAbilityLifecycleCallback success, err:
"
+
JSON
.
stringify
(
error
));
});
```
zh-cn/application-dev/reference/apis/js-apis-application-context.md
浏览文件 @
43e31630
...
@@ -61,23 +61,23 @@ createBundleContext(bundleName: string): Context;
...
@@ -61,23 +61,23 @@ createBundleContext(bundleName: string): Context;
## Context.getApplicationContext
## Context.getApplicationContext
getApplicationContext(): Context;
getApplicationContext():
Application
Context;
获取当前
c
ontext。
获取当前
applicationC
ontext。
**系统能力**
:SystemCapability.Ability.AbilityRuntime.Core
**系统能力**
:SystemCapability.Ability.AbilityRuntime.Core
**返回值:**
**返回值:**
| 类型 | 说明 |
| 类型 | 说明 |
| -------- | -------- |
| -------- | -------- |
| Context | 当前Context
信息。 |
| ApplicationContext | 当前ApplicationContext对象信息。 |
**示例:**
**示例:**
```
js
```
js
// 必选项。
// 必选项。
let
c
ontext
=
this
.
context
.
getApplicationContext
();
let
applicationC
ontext
=
this
.
context
.
getApplicationContext
();
```
```
...
@@ -112,4 +112,4 @@ switchArea(mode: AreaMode): void;
...
@@ -112,4 +112,4 @@ switchArea(mode: AreaMode): void;
| 变量 | 值 | 描述 |
| 变量 | 值 | 描述 |
| --------------- | ---- | --------------- |
| --------------- | ---- | --------------- |
| EL1 | 0 | 设备级加密区。 |
| EL1 | 0 | 设备级加密区。 |
| EL2 | 1 | 用户凭据加密区。默认为EL2。 |
| EL2 | 1 | 用户凭据加密区。默认为EL2。 |
\ No newline at end of file
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录