• Home
  • Line#
  • Scopes#
  • Navigate#
  • Raw
  • Download
1# UIAbility Component Usage
2
3
4When using the UIAbility component, you must specify a startup page and obtain the context, [UIAbilityContext](../reference/apis/js-apis-inner-application-uiAbilityContext.md).
5
6
7## Specifying the Startup Page of UIAbility
8
9If no startup page is specified, a white screen occurs after the application is started. You can use **loadContent()** of [WindowStage](../reference/apis/js-apis-window.md#windowstage9) to set the startup page in the **onWindowStageCreate()** callback of the UIAbility instance.
10
11
12```ts
13import UIAbility from '@ohos.app.ability.UIAbility';
14import window from '@ohos.window';
15
16export default class EntryAbility extends UIAbility {
17    onWindowStageCreate(windowStage: window.WindowStage) {
18        // Main window is created. Set a main page for this ability.
19        windowStage.loadContent('pages/Index', (err, data) => {
20            // ...
21        });
22    }
23
24    // ...
25}
26```
27
28> **NOTE**
29>
30> When you create UIAbility in DevEco Studio, the UIAbility instance loads the **Index** page by default. Therefore, you only need to replace the **Index** page path with the required startup page path.
31
32
33## Obtaining the Context of UIAbility
34
35The UIAbility class has its own context, which is an instance of the [UIAbilityContext](../reference/apis/js-apis-inner-application-uiAbilityContext.md) class. The UIAbilityContext class has attributes such as **abilityInfo** and **currentHapModuleInfo**. UIAbilityContext can be used to obtain the UIAbility configuration information, such as the bundle code path, bundle name, ability name, and environment status required by the application. It can also be used to obtain methods to operate the UIAbility instance, such as **startAbility()**, **connectServiceExtensionAbility()**, and **terminateSelf()**.
36
37- You can use **this.context** to obtain the context of a UIAbility instance.
38
39  ```ts
40  import UIAbility from '@ohos.app.ability.UIAbility';
41
42  export default class EntryAbility extends UIAbility {
43      onCreate(want, launchParam) {
44          // Obtain the context of the UIAbility instance.
45          let context = this.context;
46
47          // ...
48      }
49  }
50  ```
51
52- Import the context module and define the **context** variable in the component.
53
54  ```ts
55  import common from '@ohos.app.ability.common';
56
57  @Entry
58  @Component
59  struct Index {
60    private context = getContext(this) as common.UIAbilityContext;
61
62    startAbilityTest() {
63      let want = {
64        // Want parameter information.
65      };
66      this.context.startAbility(want);
67    }
68
69    // Page display.
70    build() {
71      // ...
72    }
73  }
74  ```
75
76  You can also define variables after importing the context module but before using [UIAbilityContext](../reference/apis/js-apis-inner-application-uiAbilityContext.md).
77
78
79  ```ts
80  import common from '@ohos.app.ability.common';
81
82  @Entry
83  @Component
84  struct Index {
85
86    startAbilityTest() {
87      let context = getContext(this) as common.UIAbilityContext;
88      let want = {
89        // Want parameter information.
90      };
91      context.startAbility(want);
92    }
93
94    // Page display.
95    build() {
96      // ...
97    }
98  }
99  ```
100