Android视角看鸿蒙第七课(module.json5中的各字段含义之abilities)

Android视角看鸿蒙第七课(module.json5中的各字段含义之abilities)

导读

今天一起来了解module.json5中的最后一个字段,也是最复杂的字段abilities

官方文档

Indicates all abilities in the current module. The value is an array of objects, each of which represents an ability.This label can be left blank by default,and indicates no capability exists in the current module.

字段声明

项目内截图

思考

字段要求是一个数组,描述了所有ability,类似于activity的声明。可以没有任何内容。

下面尝试两个问题:

1:EntryAbility不声明会发生什么;

2:SecondAbility不声明会发生什么;

尝试

EntryAbility不声明会发生什么

全部注释掉了,无警告。

运行

结论

entryModule中没有声明启动ability时,可以打包并安装成功,但会因为没有配置启动ability而导致没有桌面图标,同时也无法启动。

可以确认安装成功

SecondAbility不声明会发生什么

我们把EntryAbility的注释放开,同时把SecondAbility注释

在index中点击跳转到SecondAbility

运行

点击跳转的时候,没有任何提示,也不奔溃。

日志也不是特别清晰。

03-19 10:56:19.122 733-855/? I 02D01/EventLogger: OnEvent: event jsonExtraInfo is {"domain_":"AAFWK","name_":"START_ABILITY_ERROR","type_":1,"time_":1710816979113,"tz_":"+0800","pid_":26,"tid_":61,"uid_":5523,"USER_ID":-1,"BUNDLE_NAME":"com.example.myapplication","MODULE_NAME":"app","ABILITY_NAME":"SecondAbility","ERROR_CODE":2097152, "transfer_":1}

结论

非启动Ability不声明,会导致无法启动此Ability,但页面不会闪退,也无任何提示。日志级别也不是特别清晰。遇到类似问题,建议日志过滤START_ABILITY_ERROR

所有子字段

name
文档
字段声明

这里很重要,必须从这两个中选一个,即name必须存在。

有最大长度限制,不允许索引。

尝试

这里实际使用时,建议还是要和文件名相同,本着深入了解的目的,这里测试一下随意自定义name和want跳转的关系。

把SecondAbility的注释放开,同时修改name为second

want使用的abilityName先不改,看看这里的abilityName使用的是文件名还是json5中声明的名字

运行

跳转失败了。

换成刚刚修改过的second

运行

03-19 11:39:48.462 6087-85/? D 02D10/HiView-SysEventSource: Parser: parser raw message size=247, {"domain_":"AAFWK","name_":"START_ABILITY_ERROR","type_":1,"time_":1710819588357,"tz_":"+0800","pid_":16,"tid_":16,"uid_":5523,"USER_ID":-1,"BUNDLE_NAME":"com.example.myapplication","MODULE_NAME":"app","ABILITY_NAME":"second","ERROR_CODE":2097177}

报错了 看看这个error是什么意思

找不到文档,换个方式

运行

绝了,啥也没有。

研究研究
发现问题了,SecondAbility和EntryAbility一样都是加载的pages/Index,模拟器上也没看出来页面切换,实际上是成功的。

新建了一个page给SecondAbility,就看出效果了。

这样的话,再改回去,name改成SecondAbility看看能不能跳转

不能,这回错误日志,也更加清晰了。

结论

name相当于给Ability起个别名,want跳转的时候使用的是别名,而不是文件名。

使用want,最好关注下结果,否则的话错误原因不好定位。

我把这个日志过滤了一下,只有这么两句,第二句还是我自己打的,第一句是Debug级别。

srcEntry
官方文档
字段描述
思考

其实很简单,String类型的Ability地址,用来正确的指向Ability文件。

在abilities字段描述中,有下图

其实就是srcEntrance和srcEntry二选一,我特意看了一下srcEntrance的描述

发现只是过期了,所以srcEntrance不再关注。

下面我们依然尝试两个问题

1、全路径行不行,带中文行不行

2、library(feature module)中的ability定义在entry行不行

尝试(全路径行不行)

不行,直接报错。

第二个问题也不存在了

尝试(中文行不行)

直接修改文件夹为中文试试

修改成功了,srcEntry也自动变化了。

运行看看

跑不起来。

还是别搞骚操作了。

结论

只能使用相对路径。带中文的不行。

description

这个字段我们在之前的文章说过,感兴趣的同学翻回去看看,这里直接上结论
之前讲description的文章

结论
icon&label
官方文档
字段描述
思考

讲如何修改桌面图标的文章

在上面的文章中,我们确定了桌面图标是由携带

这两个字段的ability的label和icon决定的。

那么为什么我新创建的ability也默认携带这两个字段呢?

会不会还有其他用处?

答案是有的

在运行中的任务中,两个ablity都是存在的,所以ablity并不等同于activity,而且这两个ability各自使用了各自的label及icon。

下面尝试几个问题

1、SecondAbility不配置icon及label如何展示

2、EntryAbility不配置会如何

尝试SecondAbility不配置icon及label

把second下的label注释掉

运行

若Ability不配置label和icon,则使用app.json5中的应用icon和label。

EntryAbility不配置label和icon会如何

把EntryAbility 的label和icon注释掉

运行

结论

1、每个ability在运行中应用列表都显示单独配置的图标及名称,若未配置则显示app.json5中配置的应用图标及名称

2、entryAbility若未配置图标及名称,默认取用app.json5中配置的应用图标和名称。

other

有点太多了,下篇文章继续讲吧。

相关推荐
DIY机器人工房17 分钟前
科普:华为星闪是什么?华为星闪(英文名 NearLink)是国际星闪无线短距通信联盟发布的新型无线短距通信标准技术。
stm32·嵌入式硬件·华为·嵌入式·diy机器人工房·嵌入式面试题
天黑请闭眼33 分钟前
华为对象存储:nginx代理临时访问地址后访问报错:Authentication Failed
nginx·华为
GISer_Jing1 小时前
跨平台Hybrid App开发实战指南
android·flutter·react native
凌波粒1 小时前
SpringMVC基础教程(2)--Controller/RestFul风格/JSON/数据转发和重定向
java·后端·spring·json·restful
新之助小锅3 小时前
java版连接汇川PLC,发送数据,读取数据,保持重新链接,适用安卓
android·java·python
2501_916007474 小时前
iOS性能调试工具终极指南,从系统底层到多端协同的全方位优化实践(2025版)
android·ios·小程序·https·uni-app·iphone·webview
2501_915921434 小时前
iOS崩溃日志深度分析与工具组合实战,从符号化到自动化诊断的完整体系
android·ios·小程序·uni-app·自动化·cocoa·iphone
执念WRD7 小时前
熊海CMS v1.0代码审计实战
android·nginx·安全·web安全·网络安全·系统安全
jllllyuz7 小时前
基于ThinkPHP实现动态ZIP压缩包的生成
android
百***920210 小时前
【MySQL】MySQL库的操作
android·数据库·mysql