1# getContext 2 3如果需要在页面中获得当前Ability的Context,可调用getContext接口获取当前页面关联的UIAbilityContext或ExtensionContext。 4 5> **说明:** 6> - 该接口从API version 9开始支持。 7> - 该接口仅限Stage模型使用。 8 9## getContext 10getContext(component?: Object):Context 11 12获取与页面上下文组件关联的Context对象。 13 14**原子化服务API:** 从API version 11开始,该接口支持在原子化服务中使用。 15 16**系统能力:** SystemCapability.ArkUI.ArkUI.Full 17 18**参数:** 19 20| 参数名 | 类型 | 必填 | 说明 | 21| ------ | ----------- | ---- | ------------------------------- | 22| component | Object | 否 | 当前自定义组件的实例。未传入component或传入的参数类型非法,则返回默认上下文。默认上下文是指通过追溯当前方法的调用链所跟踪到的Context。在异步调用的回调方法中使用该接口,或者该接口的起始调用不在当前页面,将可能导致无法跟踪到该实例的Context,则会返回undefined。 | 23 24**返回值:** 25 26| 类型 | 说明 | 27| ------ | ------------------------------- | 28| [Context](../../application-models/application-context-stage.md#应用上下文context) | 返回当前组件所在Ability的Context,Context的具体类型为当前Ability关联的Context对象。例如:在UIAbility窗口中的页面调用该接口,返回类型为UIAbilityContext。在ExtensionAbility窗口中的页面调用该接口,返回类型为ExtensionContext。 | 29 30**示例:** 31 32在UIAbility中通过windowStage.loadContent加载具体页面。 33 34> **说明:** 35> 36> 直接使用getContext可能导致实例不明确的问题,建议使用[getUIContext](js-apis-arkui-UIContext.md#uicontext)获取UIContext实例,并使用[getHostContext](js-apis-arkui-UIContext.md#gethostcontext12)调用绑定实例的getContext。 37 38```ts 39// EntryAbility.ets 40import { UIAbility, AbilityConstant, Want } from '@kit.AbilityKit'; 41import { hilog } from '@kit.PerformanceAnalysisKit'; 42import { window } from '@kit.ArkUI'; 43 44export default class EntryAbility extends UIAbility { 45 onCreate(want: Want, launchParam: AbilityConstant.LaunchParam) { 46 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onCreate'); 47 } 48 49 onDestroy() { 50 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onDestroy'); 51 } 52 53 onWindowStageCreate(windowStage: window.WindowStage) { 54 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageCreate'); 55 56 windowStage.loadContent('pages/Index', (err, data) => { 57 if (err.code) { 58 hilog.error(0x0000, 'testTag', 'Failed to load the content. Cause: %{public}s', JSON.stringify(err) ?? ''); 59 return; 60 } 61 hilog.info(0x0000, 'testTag', 'Succeeded in loading the content. Data: %{public}s', JSON.stringify(data) ?? ''); 62 }); 63 } 64 65 onWindowStageDestroy() { 66 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onWindowStageDestroy'); 67 } 68 69 onForeground() { 70 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onForeground'); 71 } 72 73 onBackground() { 74 hilog.info(0x0000, 'testTag', '%{public}s', 'Ability onBackground'); 75 } 76} 77``` 78在具体的Index.ets中可以通过getContext接口获取Context上下文,本示例返回的Context类型为UIAbilityContext。 79 80```ts 81//pages/Index.ets 82@Entry 83@Component 84struct Index { 85 @State message: string = 'Hello World' 86 87 build() { 88 Row() { 89 Column() { 90 Text(this.message) 91 .fontSize(50) 92 .fontWeight(FontWeight.Bold) 93 .onClick(() => { 94 // 建议使用this.getUIContext().getHostContext() 95 let context : Context = getContext(this) as Context 96 console.info("CacheDir:" + context.cacheDir) 97 }) 98 } 99 .width('100%') 100 } 101 .height('100%') 102 } 103} 104``` 105