codecamp

UIAbility组件基本用法

UIAbility组件的基本用法包括:指定UIAbility的启动页面以及获取UIAbility的上下文UIAbilityContext

指定UIAbility的启动页面

应用中的UIAbility在启动过程中,需要指定启动页面,否则应用启动后会因为没有默认加载页面而导致白屏。可以在UIAbility的onWindowStageCreate()生命周期回调中,通过WindowStage对象的loadContent()方法设置启动页面。

  1. import UIAbility from '@ohos.app.ability.UIAbility';
  2. import Window from '@ohos.window';
  3. export default class EntryAbility extends UIAbility {
  4. onWindowStageCreate(windowStage: Window.WindowStage) {
  5. // Main window is created, set main page for this ability
  6. windowStage.loadContent('pages/Index', (err, data) => {
  7. // ...
  8. });
  9. }
  10. // ...
  11. }
说明

在DevEco Studio中创建的UIAbility中,该UIAbility实例默认会加载Index页面,根据需要将Index页面路径替换为需要的页面路径即可。

获取UIAbility的上下文信息

UIAbility类拥有自身的上下文信息,该信息为UIAbilityContext类的实例,UIAbilityContext类拥有abilityInfo、currentHapModuleInfo等属性。通过UIAbilityContext可以获取UIAbility的相关配置信息,如包代码路径、Bundle名称、Ability名称和应用程序需要的环境状态等属性信息,以及可以获取操作UIAbility实例的方法(如startAbility()、connectServiceExtensionAbility()、terminateSelf()等)。

  • 在UIAbility中可以通过this.context获取UIAbility实例的上下文信息。

    1. import UIAbility from '@ohos.app.ability.UIAbility';
    2. export default class EntryAbility extends UIAbility {
    3. onCreate(want, launchParam) {
    4. // 获取UIAbility实例的上下文
    5. let context = this.context;
    6. // ...
    7. }
    8. }
  • 在页面中获取UIAbility实例的上下文信息,包括导入依赖资源context模块和在组件中定义一个context变量两个部分。

    1. import common from '@ohos.app.ability.common';
    2. @Entry
    3. @Component
    4. struct Index {
    5. private context = getContext(this) as common.UIAbilityContext;
    6. startAbilityTest() {
    7. let want = {
    8. // Want参数信息
    9. };
    10. this.context.startAbility(want);
    11. }
    12. // 页面展示
    13. build() {
    14. // ...
    15. }
    16. }

    也可以在导入依赖资源context模块后,在具体使用UIAbilityContext前进行变量定义。

    1. import common from '@ohos.app.ability.common';
    2. @Entry
    3. @Component
    4. struct Index {
    5. startAbilityTest() {
    6. let context = getContext(this) as common.UIAbilityContext;
    7. let want = {
    8. // Want参数信息
    9. };
    10. context.startAbility(want);
    11. }
    12. // 页面展示
    13. build() {
    14. // ...
    15. }
    16. }
UIAbility组件启动模式
UIAbility组件与UI的数据同步
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录
HAR

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }