1# Ability框架开发常见问题 2 3## Stage模型中是否有类似FA模型的DataAbility的开发指导文档 4 5适用于:OpenHarmony SDK 3.2.3.5版本, API9 Stage模型 6 7Stage模型中DataShareExtensionAbility提供了向其他应用共享以及管理其数据的方法。 8 9参考文档:[数据共享开发指导](../database/database-datashare-guidelines.md) 10 11## 拉起Ability在界面上没反应 12 13适用于:OpenHarmony SDK 3.2.5.3版本,API9 Stage模型 14 151. 如果是通过startAbility的方式拉起,检查want中abilityName字段是否携带了bundleName做前缀,如果有,请删除; 16 172. 检查MainAbility.ts文件中onWindowStageCreate方法配置的Ability首页文件是否在main_pages.json中有定义,如果没有定义,请补齐; 18 193. SDK和OpenHarmony SDK系统推荐同一天的版本。 20 21参考文档:[OpenHarmony版本转测试信息](https://gitee.com/openharmony-sig/oh-inner-release-management/blob/master/Release-Testing-Version.md) 22 23## 如何将Ability的UI界面设置成透明 24 25适用于:OpenHarmony SDK 3.2.3.5版本,API9 Stage模型 26 27将最上层容器组件背景色设置为透明,然后通过设置XComponent组件的opacity属性值为0.01来实现。 28 29 示例: 30 31``` 32build() { 33 Stack() { 34 XComponent({ 35 id: 'componentId', 36 type: 'surface', 37 }) 38 .width('100%') 39 .height('100%') 40 .opacity(0.01) 41 // 页面内容 42 } 43 .width('100%') 44 .height('100%') 45 .backgroundColor('rgba(255,255,255, 0)') 46} 47``` 48 49## 调用方法的时候,如何解决方法内部的this变成undefined 50 51适用于:OpenHarmony SDK 3.2.5.3版本,API9 Stage模型 52 53方式一:在调用方法的时候加上.bind(this)。 54 55方式二:使用箭头函数。 56 57## 如何解决must have required property 'startWindowIcon'报错 58 59适用于:OpenHarmony SDK 3.2.3.5版本,API9 Stage模型 60 61Ability配置中缺少startWindowIcon属性配置,需要在module.json5中abilities中配置startWindowIcon。 62 63参考文档:[Stage模型应用程序包结构](../quick-start/module-configuration-file.md) 64 65示例: 66 67``` 68{ 69 "module": { 70 // do something 71 "abilities": [{ 72 // do something 73 "startWindowIcon": "$media:space", 74 "startWindowBackground": "$color:white", 75 }] 76 } 77} 78``` 79 80## 如何获取设备横竖屏的状态变化的通知 81 82适用于:OpenHarmony SDK 3.2.3.5版本, API9 Stage模型 83 84使用Ability的onConfigurationUpdated回调实现,系统语言、颜色模式以及Display相关的参数,比如方向、Density,发生变化时触发该回调。 85 86参考文档:[Ability开发指导](../ability/stage-ability.md) 87 88## Stage模型是否推荐用globalThis去获取Context 89 90适用于:OpenHarmony SDK 3.2.5.5版本,API9 Stage模型 91 92不推荐,Stage模型使用globalThis去获取Context是错误的使用方式。在Stage模型中,整个应用进程共用一个js虚拟机实例,其中可以运行多个Ability实例,共用一个global对象。在同一个js虚拟机内的不同的Ability中使用globalThis获取Context,存在被覆盖从而发生错误的风险。 93 94推荐使用方式参考:[Stage模型的Context详细介绍](../ability/context-userguide.md#stage模型的context详细介绍)。 95 96## 如何在应用A中去获取应用B的Hap包的安装路径 97 98适用于:OpenHarmony SDK 3.0以上版本, API9 Stage模型 99 100首先需要申请系统权限,具体参看文档:[自动化签名](https://developer.harmonyos.com/cn/docs/documentation/doc-guides/ohos-auto-configuring-signature-information-0000001271659465)。导入bundle模块,通过调用bundle.getApplicationInfo()接口,通过包名获取应用信息。然后通过application.moduleSourceDirs获取应用存储路径。 101 102## 调用方使用startAbilityForResult,被调用方如何返回数据 103 104适用于:OpenHarmony SDK3.0, API9 Stage模型 105 106被调用方使用AbilityContext.terminateSelfWithResult方法,销毁被调用方ability,传递参数给startAbilityForResult回调函数,具体用法请参考[AbilityContext](../reference/apis/js-apis-ability-context.md#abilitycontextterminateselfwithresult) 107 108## FA卡片上架后在用户的服务中心展示时可否触发生命周期,从而实现用户没有打开过FA应用的情况下获取到用户的登录信息? 109 110适用于:OpenHarmony SDK 3.2.5.5版本, API8 FA模型 111 112服务卡片在添加卡片后就触发了oncreate()生命周期,在不启用app的情况下也可以显示相关的用户信息-静默登录,但服务卡片目前要在app安装之后手动添加。 113 114## 如何获取context 115 116适用于:OpenHarmony SDK 3.2.7.5版本, API9 Stage模型 117 118在MainAbility.ts文件中可以直接使用this.context获取context,在组件页面中可以使用getContext(this)获取context。 119 120## 访问控制管理模块abilityAccessCtrl中grantUserGrantedPermission方法在API8语法校验提示未定义 121 122适用于:OpenHarmony SDK 3.0版本, API8 FA模型 123 124当前SDK有fullSDK和publicSDK两个版本,IDE默认下载的是publicSDK。其中,publicSDK版本不会包含系统API,如果要用系统API,需要使用fullSDK。具体参考[full-SDK替换指南](../quick-start/full-sdk-switch-guide.md)。 125 126## public sdk支持哪几种ExtensionAbility(ServiceExtensionAbility、FormExtensionAbility、DataShareExtensionAbility) 127 128适用于:OpenHarmony SDK 3.2.5.6版本, API9 Stage模型 129 130上述ExtensionAbility 中,public sdk 仅可以使用FormExtensionAbility。ServiceExtensionAbility和DataShareExtensionAbility 为系统接口,需要使用full sdk。 131 132Public SDK : 面向应用开发者提供,不包含需要使用系统权限的系统接口。 133 134Full SDK : 面向OEM厂商提供,包含了需要使用系统权限的系统接口。 135 136## 服务卡片无法循环播放gif图 137 138适用于:OpenHarmony SDK 3.2.5.6版本, API9 Stage模型 139 140目前暂不支持播放GIF图片。 141 142## 如何通过卡片点击实现业务登录场景 143 144适用于:OpenHarmony SDK 3.2.5.5版本, API9 Stage模型 145 146可以通过点击卡片拉起响应的Ability后,通过Ability来实现业务登录场景。 147 148## 如何跳转到设置中应用详情页面 149 150使用于:OpenHarmony SDK 3.2.6.5版本 151 152参考如下代码实现,示例: 153 154``` 155this.context.startAbility( 156{ 157 action: "action.settings.app.info", 158 parameters: { "settingsParamBundleName": "your app bundlename" } 159}) 160``` 161 162## 如何监听屏幕旋转 163 164使用于:OpenHarmony SDK 3.2.5.5版本,API9 Stage模型 165 166参考如下代码实现,示例: 167 168``` 169let listener = mediaquery.matchMediaSync('(orientation: landscape)') 170onPortrait(mediaQueryResult) { 171if (mediaQueryResult.matches) { 172// do something here 173 } else { 174// do something here 175 } 176} 177listener.on('change', onPortrait) 178``` 179 180## 如何控制checkbox选中切换过程中阴影背景的大小 181 182使用于:OpenHarmony SDK 3.2.5.5版本,API9 Stage模型 183 184设置checkbox组件padding属性,可控制阴影大小 185 186## 如何设置卡片背景为透明 187 188适用:OpenHarmony SDK 3.2.5.5版本 189 1901. 在卡片根目录widget新建widget/resources/styles/default.json文件 191 1922. 在default.json中书写如下代码: 193 194``` 195{ 196 "style": { 197 "app_background": "#00000000" 198 } 199} 200``` 201 202## FA卡片如何的传参和接参 203 204适用:OpenHarmony SDK 3.2.5.5版本 205 206使用featureAbility.getWant()和featureAbility.getContext()在json文件中router跳转发送数据,在js文件中用featureAbility方法接收 207 208## router.disableAlertBeforeBackPage和router.enableAlertBeforeBackPage怎么触发 209 210适用:OpenHarmony SDK 3.2.5.5版本 211 212需要满足两个条件 213 2141. router.disableAlertBeforeBackPage和router.enableAlertBeforeBackPage类似一个开关,disableAlertBeforeBackPage是返回上一级页面时关闭弹窗提示,enableAlertBeforeBackPage是打开弹窗提示,默认是关闭的,当你需要使用时,首先要在一个函数里面开启功能,然后再执行跳转 215 2162. 必须要使用系统的返回按键才能触发效果。 217