理解鸿蒙app 开发中的 context

是什么

Context是应用中对象的上下文 ,其提供了应用的一些基础信息,例如resourceManager资源管理 )、applicationInfo当前应用信息 )、dir应用文件路径 )、area文件分区 )等,以及应用的一些基本方法,例如createBundleContext()、getApplicationContext()等。UIAbility组件和各种ExtensionAbility派生类组件都有各自不同的Context类。分别有基类Context、ApplicationContextAbilityStageContextUIAbilityContextExtensionContext、ServiceExtensionContext等Context。(应用上下文(Context)是应用程序的全局信息的接口。它是一个抽象类,提供了访问应用程序环境的方法和资源的方法 总而言之,Context提供了访问应用程序资源和服务的接口。

  • 各类Context的继承关系

各类Context的持有关系

如何获取 context

在具体的页面中获取 context 就使用 getcontext(this)

如果需要在页面中获得当前Ability的Context,可调用getContext接口获取当前页面关联的UIAbilityContext或ExtensionContext。

TypeScript 复制代码
//pages/Index.ets
@Entry
@Component
struct Index {
  @State message: string = 'Hello World'

  build() {
    Row() {
      Column() {
        Text(this.message)
          .fontSize(50)
          .fontWeight(FontWeight.Bold)
          .onClick(() => {
            // 建议使用this.getUIContext().getHostContext()
            let context : Context = getContext(this) as Context
            console.info("CacheDir:" + context.cacheDir)
          })
      }
      .width('100%')
    }
    .height('100%')
  }
}

说明:如果需要在页面中获得当前Ability的Context,可调用getContext接口获取当前页面关联的UIAbilityContext

getContext传入this和不传入有什么区别

getContext参数及类型:getContext(component?: Object):Context。

Context传入参数component的作用是指定一个组件对象,getContext函数会返回这个组件的上下文对象Context。如果不传入参数,则默认返回当前组件的上下文对象。上下文对象Context包含了组件的状态、属性、方法等信息,可以在组件内部使用。

在某些场景下,可能需要在组件内部调用其他组件的方法或获取其他组件的属性,此时可以通过getContext(this)获取到当前组件的上下文对象,然后使用该上下文对象调用其他组件的方法或获取其他组件的属性

获取UIAbility的上下文信息

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

如果需要在页面中获得当前Ability的Context,可调用getContext接口获取当前页面关联的 UIAbilityContext或ExtensionContext

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

TypeScript 复制代码
import { UIAbility, AbilityConstant, Want } from '@kit.AbilityKit';

export default class EntryAbility extends UIAbility {
  onCreate(want: Want, launchParam: AbilityConstant.LaunchParam): void {
    // 获取UIAbility实例的上下文
    let context = this.context;
//将 context   存进去 
AppStorage.setOrCreate('EntryAbilityContext', this.context);
    // ...
  }
}

注意 !!!!在生明的类里面 拿到context 方式 最好使用这种方式

TypeScript 复制代码
export class appOptionModel {
//  使用在 entry  里面存储的   EntryAbilityContext   这样才行  
context: common.UIAbilityContext | undefined = AppStorage.get('EntryAbilityContext'); // 获取UIAbilityContext

}
相关推荐
在人间耕耘1 天前
HarmonyOS Vision Kit 视觉AI实战:把官方 Demo 改造成一套能长期复用的组件库
人工智能·深度学习·harmonyos
王码码20351 天前
Flutter for OpenHarmony:socket_io_client 实时通信的事实标准(Node.js 后端的最佳拍档) 深度解析与鸿蒙适配指南
android·flutter·ui·华为·node.js·harmonyos
HarmonyOS_SDK1 天前
【FAQ】HarmonyOS SDK 闭源开放能力 — Ads Kit
harmonyos
Swift社区1 天前
如何利用 ArkUI 框架优化鸿蒙应用的渲染性能
华为·harmonyos
特立独行的猫a1 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS影视票房榜组件完整实现过程
华为·uni-app·harmonyos·轮播图·uniapp-x
盐焗西兰花1 天前
鸿蒙学习实战之路-STG系列(5/11)-守护策略管理-添加与修改策略
服务器·学习·harmonyos
盐焗西兰花1 天前
鸿蒙学习实战之路-STG系列(4/11)-应用选择页功能详解
服务器·学习·harmonyos
lbb 小魔仙2 天前
鸿蒙跨平台项目实战篇03:React Native Bundle增量更新详解
react native·react.js·harmonyos
特立独行的猫a2 天前
uni-app x跨平台开发实战:开发鸿蒙HarmonyOS滚动卡片组件,scroll-view无法滚动踩坑全记录
华为·uni-app·harmonyos·uniapp-x
不爱吃糖的程序媛2 天前
Flutter Orientation 插件在鸿蒙平台的使用指南
flutter·华为·harmonyos