Stage模型-应用配置文件

  • AppScope -> app.json5:应用的全局配置信息
  • entry:OpenHarmony工程模块,编译构建生成一个HAP
    • build:用于存放OpenHarmony编译生成的hap包
    • src -> main -> ets:用于存放ArkTS源码
    • src -> main -> ets > entryability:应用/服务的入口
    • src -> main -> ets > pages:应用/服务包含的页面
    • src -> main -> resources:用于存放项目的资源文件,如图片、音频等
    • src > main > module.json5:模块配置文件(局部)
    • build-profile.json5:当前的模块信息 、编译信息配置项,包括buildOption、targets配置等
    • hvigorfile.ts:模块级编译构建任务脚本,开发者可以自定义相关任务和代码实现
  • oh_modules:用于存放三方库依赖信息
  • build-profile.json5:应用级配置信息,包括签名signingConfigs、产品配置products等
  • hvigorfile.ts:应用级编译构建任务脚本

【HarmonyOS】鸿蒙开发之Stage模型-应用配置文件——第4.2章-LMLPHP

模块基础配置

{
  "module": {
  //模块名称(最大长度31个字节)
    "name": "entry",
    //模块类型。分别:- entry:应用的主模块。feature:应用的动态特性模块。
    "type": "entry",
    //模块描述。$string:module_desc对应:src/main/resources/element/string.json文件下的module_desc对象名
    "description": "$string:module_desc",
    //当前模块的入口名称。对应:
    "mainElement": "EntryAbility",
    //当前模块可以运行在哪类设备上
    //phone:手机 table:平板类  car:车机  wearable:手表  tv:智慧屏
    "deviceTypes": [
      "phone",
      "tablet"
    ],
    //当前模块是否在用户主动安装的时候安装,表示该Module对应的HAP是否跟随应用一起安装
    "deliveryWithInstall": true,
    //标识当前Module是否支持免安装特性。
	//- true:表示支持免安装特性,且符合免安装约束。
	//
	//- false:表示不支持免安装特性。
	//- 当应用的entry类型Module的该字段配置为true时,该应用的feature类型的该字
    "installationFree": false,
    //当前模块的profile资源,用于列举每个页面信息.其实就是路由,点进去你会发现是你在此模块下配置跳转的路由信息(跟小程序配置路由一样的意思) 对应:src/main/resouces/base/profile
    "pages": "$profile:main_pages",
    "abilities": [
      {
        "name": "EntryAbility",
        "srcEntry": "./ets/entryability/EntryAbility.ts",
        "description": "$string:EntryAbility_desc",
        "icon": "$media:icon",
        "label": "$string:EntryAbility_label",
        "startWindowIcon": "$media:icon",
        "startWindowBackground": "$color:start_window_background",
        "exported": true,
        "skills": [
          {
            "entities": [
              "entity.system.home"
            ],
            "actions": [
              "action.system.home"
            ]
          }
        ]
      }
    ],
    "requestPermissions":[
      {
        "name": "ohos.permission.INTERNET",
        "usedScene": {
          "when": "always"
        }
      }
    ]
  }
}

【HarmonyOS】鸿蒙开发之Stage模型-应用配置文件——第4.2章-LMLPHP

module->pages标签

【HarmonyOS】鸿蒙开发之Stage模型-应用配置文件——第4.2章-LMLPHP
找到main_pages.json文件设置项目路由
【HarmonyOS】鸿蒙开发之Stage模型-应用配置文件——第4.2章-LMLPHP

module->abilities标签

"abilities": [
      {
      //abilities名称
        "name": "EntryAbility",
        //abilities路径
        "srcEntry": "./ets/entryability/EntryAbility.ts",
        //abilities项目描述
        "description": "$string:EntryAbility_desc",
        //abilities项目图标
        "icon": "$media:icon",
        //启动模式 三种singleton(单实例),multiton(多实例),specified(指定实例)
        "launchType":"singleton",
        //abilities项目名称
        "label": "$string:EntryAbility_label",
        //项目窗口图标
        "startWindowIcon": "$media:icon",
        //项目进入后台时的图标
        "startWindowBackground": "$color:start_window_background",
        //标识当前UIAbility组件是否可以被其他应用调用。
		//- true:表示可以被其他应用调用。
		//- false:表示不可以被其他应用调用
		//注意如果是启动页 就是第一个页面如果是false是无法被调起的app 会报错
        "exported": true,
        "skills": [
          {
            "entities": [
              "entity.system.home"
            ],
            "actions": [
              "action.system.home"
            ]
          }
        ]
      }
    ],
  • Skills
    • actions 表示调用方要执行的通用操作(如查看、分享、应用详情)。在隐式Want中,您可定义该字段,配合uri或parameters来表示对数据要执行的操作。如打开,查看该uri数据。例如,当uri为一段网址,action为ohos.want.action.viewData则表示匹配可查看该网址的Ability。在Want内声明action字段表示希望被调用方应用支持声明的操作。在被调用方应用配置文件skills字段内声明actions表示该应用支持声明操作。
    • entities 表示目标Ability的类别信息(如浏览器、视频播放器),在隐式Want中是对action的补充。在隐式Want中,开发者可定义该字段,来过滤匹配应用的类别,例如必须是浏览器。在Want内声明entities字段表示希望被调用方应用属于声明的类别。在被调用方应用配置文件skills字段内声明entites表示该应用支持的类别。
      【HarmonyOS】鸿蒙开发之Stage模型-应用配置文件——第4.2章-LMLPHP

module->extensionAbilities标签

ExtensionAbility组件是基于特定场景(例如服务卡片、输入法等)

{
  "extensionAbilities": [
    {
      "name": "TextName",
      "srcEntry": "./test.ts",
      "icon": "$media:icon",
      "label" : "$string:extension_name",
      "description": "$string:form_description",
      "type": "form", //标识当前ExtensionAbility组件的类型,取值为:- form:卡片的ExtensionAbility。
      "permissions": ["ohos.abilitydemo.permission.PROVIDER"],
      "exported": true,
      "uri":"scheme://authority/path/query",
      "skills": [{
        "actions": [],
        "entities": [],
        "uris": []
      }],
      "metadata": [
        {
          "name": "ohos.extension.form",
          "resource": "$profile:form_config", 
        }
      ]
    }
  ]
}

type 标识当前ExtensionAbility组件的类型
说明:其中service和dataShare类型,仅支持系统应用配置,三方应用配置不生效。
form:卡片的ExtensionAbility。
workScheduler:延时任务的ExtensionAbility。
inputMethod:输入法的ExtensionAbility。
service:后台运行的service组件。
accessibility:辅助能力的ExtensionAbility。
dataShare:数据共享的ExtensionAbility。
fileShare:文件共享的ExtensionAbility。
staticSubscriber:静态广播的ExtensionAbility。
wallpaper:壁纸的ExtensionAbility。
backup:数据备份的ExtensionAbility。
window:该ExtensionAbility会在启动过程中创建一个window,为开发者提供界面开发。开发者开发出来的界面将通过abilityComponent控件组合到其他应用的窗口中。
thumbnail:获取文件缩略图的ExtensionAbility,开发者可以对自定义文件类型的文件提供缩略。
preview:该ExtensionAbility会将文件解析后在一个窗口中显示,开发者可以通过将此窗口组合到其他应用窗口中。

module->requestPermissions标签

**项目需要开启网络请求授权时用到。**例如:图片请求第三方链接时,需要配置requestPermissions信息。

 "requestPermissions":[
      {
      //填写需要使用的权限名称
        "name": "ohos.permission.INTERNET",
   	  //可选,当申请的权限为user_grant权限时此字段必填。描述权限使用的场景由abilities和when组成。其中abilities可以配置为多个UIAbility组件,when表示调用时机。
	 //说明:- 默认为可选,当申请的权限为user_grant权限时,abilities标签必填,when标签可选。
        "usedScene": {
          "when": "always"
        }
      }
    ],
02-27 13:10