1# API接口说明模板 2 3## 总体写作说明 4 5> **说明**:<br/>所有的写作说明,在完成写作后,都要删除。 6 7| | 说明项 | 细则 | 8| ---- | --------------------------------- | ------------------------------------------------------------ | 9| 1 | 客户化写作基本要求 | **写作中,请变身开发者,对于开发者使用该API时所需的使用场景、参数选取原则、开发建议/经验、示例等信息进行清晰描述,达到指导开发者顺利使用本API进行开发的目标。** | 10| 2 | 上传路径 | markdown文件:docs/zh-cn/application-dev/reference/apis<br>图片路径:docs/zh-cn/application-dev/reference/apis/figures,并在markdown文件中通过路径\![]\(figures/xxx.jpg)或\![]\(figures/xxx.png)引用。 | 11| 3 | 文件命名 | 一个d.ts对应一个js api文档,文件名称应与模块名称保持一致,格式为:**js-apis-模块名.md**。<br/>示例:<br/>媒体@ohos.multimedia.audio,文件命名为:js-apis-audio.md<br/>电话@ohos.telephony.sms,文件命名为:js-apis-sms.md | 12| 4 | 目录修改 | 新增文件,需要修改对应的Readme,即`docs/zh-cn/application-dev/reference/apis/Readme-CN.md`。<br/>目录按字母顺序排列。 | 13| 5 | 文档结构 | - 模块说明<br/>- 起始版本说明<br/>- 导入模块/使用说明<br/>- 接口(属性、常量、方法、枚举、自定义类型)<br/> 描述顺序和代码保持一致,如果某些接口具有逻辑顺序,请注意排列。 | 14| 6 | 异步接口说明(callback、Promise) | 对于callback、Promise在方法描述、参数说明、返回值说明的具体描述要求如下:<br/>**callback**的固定句式:<br/>方法介绍:xxx(方法描述)。使用callback异步回调。<br/>参数说明:<br/>**callback\<boolean>**:回调函数。返回true表示xxx;返回false表示xxx。<br/>**callback\<Object>**:回调函数,返回xxx。例如”回调函数,返回音频采集器对象。“<br/>**AsyncCallback\<void>**:回调函数。当具体的操作(视具体接口功能描述)成功,err为undefined,否则为错误对象。<br/>**AsyncCallback\<Object x>**:回调函数。当具体的操作(视具体接口功能描述)成功,err为undefined,data为获取到的Object x;否则为错误对象。<br/>**Promise**的固定句式:<br/>方法介绍:xxx(方法描述)。使用Promise异步回调。<br/>参数说明:<br/>**Promise\<boolean>**:Promise对象。返回true表示xxx;返回false表示xxx。<br/>**Promise\<Object>**:Promise对象,返回xxx。例如”Promise对象,返回音频采集器对象。“<br/>**Promise\<void>**:Promise对象,无返回结果。 | 15| 7 | 示例代码语言 | 所有的示例代码采用代码块的样式,并标记开发语言。<br/>JS和eTS通用的标注`js`;仅eTS可用的,标注`ts`。 | 16| 8 | 链接写法 | 格式:[链接文字]\(链接内容)<br/>跨文件夹链接:[指南]\(\.\./../xxx/xxx.md),一个`../`表示上移一层文件夹。<br/>页面内链接:[接口A<sup>7+</sup>]\(#xxxa7),页面内链接和需要链接到的标题保持一致,全小写无特殊符号无标签。 | 17 18## d.ts标签与文档字段的对应关系 19 20以下字段,除版本说明外,均需下沉到每一个接口中。 21 22如果是属性、interface表格,字段全表统一无差异,可统一写在表格上方;如果有一个不一致,需全部拆开,写到每一行的“说明”里。 23 24| d.ts的标签 | 含义 | 文档字段 | 25| ---------- | ---- | ------- | 26| @since | 版本说明 | 1. 每个模块要有起始版本说明,使用引用语法“>”对接口的起始版本进行说明。接口没有标记的,默认与模块同一个起始版本。<br/>2. 已有模块新增接口使用\<sup>标签标记对应版本号。写法:`<sup>版本号+</sup>`<br/> 例如`<sup>7+</sup>`<br/> 示例:API 6已有的模块,在API 7新增了一个属性字段,则在属性后加标记,即newAttribute<sup>7+</sup>。<br/>如果新增了一个方法,则在方法标题后增加标记,即 sim.getSimIccId<sup>7+</sup>,interface、class、枚举等同理。<br/>**需要注意的特殊情况**:因匿名对象整改,导致部分接口出现外层元素版本号高于内层元素版本号情况。为避免开发者困惑,需要在此类“接口描述”处统一增加说明:为规范匿名对象的定义,API XX版本修改了此处的元素定义。其中,保留了历史匿名对象的起始版本信息,会出现外层元素@since版本号高于内层元素版本号的情况,但这不影响接口的使用。 | 27| @deprecated | 废弃说明 | 废弃内容不能直接删去,上标标注(deprecated),起始版本和废弃版本均使用引用语法“>”说明。<br/>示例:abandonmentMethod<sup>(deprecated) </sup><br/>> 从API version 4 开始支持,从API version 7 开始废弃,建议使用[newMethod]\(#newmethod)替代。| 28| @FAModelOnly / @StageModelOnly | 模型约束 | **模型约束**:此接口仅可在FA模型下使用。 <br/> **模型约束**:此接口仅可在Stage模型下使用。 | 29| @form | 卡片能力 | **卡片能力**:从API version x开始,该接口支持在ArkTS卡片中使用。 | 30| @atomicservice | 原子化服务是否可用 | **原子化服务API**:从API version x开始,该接口支持在原子化服务中使用。 | 31| @systemapi | 系统接口 | **系统接口**:此接口为系统接口。 | 32| @syscap | 系统能力 | **系统能力**:SystemCapability.xxx.xxx | 1. 如果仅涉及一个权限,格式:<br/> **需要权限**:ohos.permission.xxxx <br/>2. 如果该接口涉及多个权限,则采用“和、或”进行分割,格式:<br/> **需要权限**:ohos.permission.A 和 ohos.permission.B<br/> **需要权限:**:ohos.permission.A 或 ohos.permission.B | 33| @permission | 权限 | 1. 如果仅涉及一个权限,格式:<br/> **需要权限**:ohos.permission.xxxx <br/>2. 如果该接口涉及多个权限,则采用“和、或”进行分割,格式:<br/> **需要权限**:ohos.permission.A 和 ohos.permission.B<br/> **需要权限**:ohos.permission.A 或 ohos.permission.B <br/>3. 涉及版本变更时,“需要权限”后跟当前版本的权限要求,历史版本的权限要求换行按列表描述,样例:<br/>**需要权限**:ohos.permission.A <br/>- 在API x-(y-1)时,需要申请权限ohos.permission.A和B。<br/>- 从API y开始,仅需申请ohos.permission.A。<br/>4. 仅在某些固定场景下,需要申请权限。“需要权限”后跟d.ts的@permission保持一致,再补充情况说明,分为两类情况,当情况较为简单时,可采用括号补充描述;当情况较为复杂时,换行描述。<br/>样例1:<br/> **需要权限**:ohos.permission.A(仅当创建窗口类型为AA时需要申请)<br/>样例2:<br/> **需要权限**:ohos.permission.A<br/>- 当应用处于xx情况时,需要同步申请ohos.permission.B。<br/>- 当应用处于yy情况时,无需申请任何权限。| 34| @extends | 继承 | 带有该标签或实际存在extends关系但未带该标签时,在相关描述处应明确说明“xxx继承自xxx(提供链接)。” | 35 36下面进入具体每个API的写作。 37 38*** 39 40# 文档标题 41 42> *写作说明* 43> 44> 1. **文档标题**:作为文档标题,要求使用中文短语概括本模块功能;但如果部分概念使用英文更便于开发者理解,可以直接使用。如Ability、SIM卡管理等。 45> 2. **标题层级**:文档标题为一级标题,使用`# `;namespace下的属性字段、function、class、interface、enum、type为二级标题,使用`## `;class下的属性、function为三级标题,使用`### `。 46> 3. **起始版本说明**:使用markdown的引用语法“>”对接口的起始版本进行说明,说明后需要换行。<br/>版本说明统一放在模块描述之后。一个模块只会有一个起始版本。<br/>采用标准句式:“本模块首批接口从API version x开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。”x需要修改为对应的版本号。 47 48模块描述。此处对该模块的定义、功能、使用场景、使用建议进行描述,采用如下固定句式。 49 50(模块介绍,可选)xxx是xxx。 51 52(功能描述,必选)xxx模块提供xxx能力,包括xxx、xxx等。——当模块名不够语义化时,推荐此句式。 53 54或 本模块提供xxx能力,包括xxx、xxx等。——当模块名已经表达了清晰的语义时,推荐此句式。 55 56(使用场景,可选)当需要xxx时,使用本模块接口xxx。 57 58(使用建议或注意事项,可选)本模块接口可与xxx联合使用,以提升开发效率……。 59 60**举例1**:“后台任务管理模块”的模块描述示例 61 62本模块提供后台任务管理能力。 63当应用或业务模块处于后台(无可见界面)时,如果有需要继续执行或者后续执行的业务,可基于业务类型,申请短时任务延迟挂起(Suspend),或长时任务避免进入挂起状态。 64 65**举例2**:“拨打电话模块”的模块描述示例 66 67本模块提供呼叫管理能力,包括拨打电话、跳转到拨号界面、获取通话状态、格式化电话号码等。 68如需订阅通话状态,请使用observer.on('callStateChange')。 69 70**举例3**:“分布式数据管理模块”的模块描述示例 71 72分布式数据管理模块为应用程序提供不同设备间数据库的分布式协同能力。 73通过调用分布式数据各个接口,应用程序可将数据保存到分布式数据库中,并可对分布式数据库中的数据进行增加、删除、修改、查询、同步等操作。 74 75**举例4**:“线性容器ArrayList模块”的模块描述示例 76 77ArrayList是一种线性数据结构,底层基于数组实现。ArrayList会根据实际需要动态调整容量,每次扩容增加50%。 78ArrayList和Vector相似,都是基于数组实现。它们都可以动态调整容量,但Vector每次扩容增加1倍。 79ArrayList和LinkedList相比,ArrayList的随机访问效率更高。但由于ArrayList的增删操作会影响数组内其他元素的移动,LinkedList的增加和删除操作效率更高。 80当需要频繁读取集合中的元素时,推荐使用ArrayList。 81 82 83 84> **说明:**<br/> 85> 本模块首批接口从API version 8开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 86 87## 导入模块 88 89> *写作说明* 90> 91> 1. 根据实际情况填写导入模块。采用代码段的样式,给出import语句。 92> 93> 2. 如果没有导入模块,将“导入模块”修改为“使用说明”。<br/>使用说明案例:<br/> 94> 在使用AbilityContext的功能前,需要通过\[getContext()]\(链接到对应的接口说明文件中.md)先获取Context对象。 95> 96> ```js 97> import { featureAbility } from '@kit.AbilityKit'; 98> let context = featureAbility.getContext(); 99> ``` 100 101```js 102import { call } from '@kit.TelephonyKit'; 103``` 104 105## 属性 106 107> *写作说明* 108> 109> 1. 可选,如果没有属性可删除此二级标题。 110> 111> 2. 类型如果为自定义类型,需要建立链接到对应的interface或enum中。 112> 113> 3. 对于只读属性:d.ts中标有`readonly`字样。如果取值为有特殊含义的有限值,需要在说明里枚举,或是通过类型链接到对应枚举类型。 114> 115> 4. 对于可选属性:如果仅支持固定字段,需要进行说明。如该属性定义时,带有?,即为可选。 116 117**系统能力**:SystemCapability.xxx.xxx(必选) 118 119| 名称 | 类型 | 只读 | 可选 | 说明 | 120| ---------------- | ----------------------------------------- | ---- | ---- | ------------------------------------------ | 121| pluggedType | [BatteryPluggedType](#batterypluggedtype) | 是 | 否 | 表示当前设备连接的充电器类型。 | 122| isBatteryPresent | boolean | 是 | 否 | 表示当前设备是否支持电池或者电池是否在位。 | 123 124## 常量 125 126> *写作说明* 127> 128> 1. 可选,如果没有常量可删除此二级标题,对应d.ts中的const。 129> 2. 部分const用于定义只读变量,无对应值,此时表格为:名称、类型、只读、说明,四列。 130> 3. 类型如果为自定义类型,需要建立链接到对应的interface或enum中。 131 132**系统能力**:SystemCapability.xxx.xxx(必选) 133 134| 名称 | 类型 | 值 | 说明 | 135| ---------------- | -----------------------------------| -------- | ------------------------------------------ | 136| uid | number | 1 | 进程的用户标识。 | 137| pid | number | 2 | 当前进程的pid。 | 138 139## 方法 140 141> *写作说明* 142> 143> 1. 可选,如果没有可删除。如果有多个方法,请分多个二级内容描述,并使用“##”自行新建二级标题。 144> 145> 2. 二级标题名为方法名,采用导入类.方法名,如果是订阅方法,需要在方法名加上对应的订阅事件。 146> 147> 示例: sim.getSimIccId 148> 订阅方法:sim.on('exampleEvent') 149> 150> 3. **方法具体调用形式**:和d.ts保持一致,需要包括关键字(static、abstract、set、get等)、参数类型、参数名、返回值类型。 151> 152> 示例: 153> 154> getNetworkState(slotId: number, callback: AsyncCallback\<NetworkState>): void 155> 156> abstract makeNode(uiContext: UIContext): FrameNode | null 157> 158> 注意1:尖括号<>可能会被识别为标签,导致界面显示失效,可增加一个\,以保证界面正常显示,如“\\<>”或使用转义字符\< \> 。 159> 160> 注意2:如果set和get关键字声明的方法成对出现,名称相同。则共用同一标题,顺序描述方法具体调用形式、标签、参数、返回值等说明。建议set方法在前,get方法在后。请参考[backgroundColor](../../application-dev/reference/apis-arkui/js-apis-arkui-renderNode.md#backgroundcolor)。 161> 162> 4. **方法描述**:对方法实现的功能进行描述,包括其使用的前提条件(*如:在xx方法调用后才能调用、需要确保网络已连接……*)、使用之后的影响(*如:调用该接口后再进行xx将不起效*)、**权限限制**、**系统能力**等。 163> 164> 5. **异步方法描述**:存在大量异步方法,其返回方式需要在方法描述处进行说明。具体写法参考总体写作说明第14项。 165> 166> 6. **表格内换行**:markdown语法中,换行采用特殊标记\<br> 167 168*(在此处给出方法的具体调用形式。如果存在关键字需说明)* 方法名称(参数1名称:参数1类型,参数2名称:参数2类型,……):返回值类型 169 170在此处给出方法描述。说明请参考上述写作说明第4、5点。 171 172**模型约束**:此接口仅可在FA模型下使用。(如不涉及可删除) 173 174**系统接口**:此接口为系统接口。(如不涉及可删除) 175 176**需要权限**:ohos.permission.xxx(如不涉及可删除) 177 178**系统能力**:SystemCapability.xxx.xxx(必选) 179 180**参数**:(可选,如不涉及可删除) 181 182| 参数名 | 类型 | 必填 | 说明 | 183| ------------ | --------------------------------------------- | ---- | ------------------------------------------------------------ | 184| parameterOne | number \| string \| [CustomType](#classinterface) | 是 | 参数描述(包括参数的含义与用途、什么场景下使用该参数、选取建议、参数间关联关系等)。<br/>参数取值说明(包括取值范围、单位、默认值、取值原则或建议值;边界值涉及限制/异常时,需讲明具体场景;如果有固定格式,需要给出格式样例,尤其是URI)。<br/>自定义类型需要进行建链说明。 | 185| callback | Callback\<Array<[CustomType](#classinterface)>> | 否 | 参数描述。可选参数需要说明不填写该参数的后果。<br/>如:不填该参数则取消该type对应的所有回调。<br/>callback写法参考总体写作说明第14项。 | 186 187**返回值**:(可选,如不涉及可删除) 188 189| 类型 | 说明 | 190| ------------------------------------------ | ----------------------------------------------- | 191| string | 返回值描述。需包含以下内容:<br/>1. 取到返回值之后,可以用来做什么。<br/>2. 返回值如果可枚举,需枚举说明返回值意义。<br/>3. 返回值如果为某个具体值/格式,需和实际实现保持一致。 | 192| Promise\<Array<[CustomType](#classinterface)>> | 返回值描述。Promise写法参考总体写作说明第14项。 | 193 194**错误码**:(可选,如不涉及可删除) 195 196以下错误码的详细介绍请参见[ohos.window(窗口)错误码]()。*(链接到对应模块的“错误码参考”文档)* 197 198| 错误码ID | 错误信息(此处仅提供错误抛出的关键信息) | 199| -------- | ---------------------------------------- | 200| 1300001 | This is repeat operation. | 201| 1300002 | This window state is abnormally. | 202 203**示例:** 204 205```js 206// 必选项。 207 208// 所有的示例代码需要进行自检,确保运行结果符合预期。 209// 不能出现缺符号、变量前后不一致等低错。 210// 所有使用到的变量要进行声明。 211// 接口传参异常时,需验证代码能否捕获错误,抛出对应错误码。 212 213// 不允许直接写参数名,必须是可使用、易替代的实际用例。如果非用户自定义填写,需通过注释进行说明。 214// 例如:let result = xxx.createExample(parameterOne); // parameterOne由扫描自动获取 215 216// 注释要精简、突出要点。需提供注释的典型场景还有: 217// 1. 当代码不能说明变量命名的具体含义,或不能说明代码逻辑时,必须提供注释。 218// 2. 涉及到复杂算法或特殊语法时,必须提供注释。 219``` 220 221## on/off订阅方法 222 223> *写作说明* 224> 225> 1. 与[方法](#方法)要求一致,以下仅作差异项说明。 226> 227> 2. 二级标题名为方法名,采用导入类.方法名,需要在方法名加上对应的订阅事件。 228> 示例:sim.on('exampleEvent') 、on('play' | 'pause' | 'stop' | 'reset') 229> 230> 3. **方法具体调用形式**:和d.ts保持一致,需要包括参数类型、事件名、参数名、返回值类型。 231> 示例:on(type: 'ringerModeChange', callback: Callback\<AudioRingMode>): void 232> 注意:尖括号<>可能会被识别为标签,导致界面显示失效,可增加一个\,以保证界面正常显示,如“\\<>”或使用转义字符\< \> 。 233 234*(在此处给出方法的具体调用形式。如果是静态方法需说明)* 方法名称(参数1名称:参数1类型,参数2名称:参数2类型,……):返回值类型 235 236在此处给出方法描述。说明请参考上述写作说明第4、5点。 237 238**模型约束**:此接口仅可在FA模型下使用。(如不涉及可删除) 239 240**系统接口**:此接口为系统接口。(如不涉及可删除) 241 242**需要权限**:ohos.permission.xxx(如不涉及可删除) 243 244**系统能力**:SystemCapability.xxx.xxx(必选) 245 246**参数:**(可选,如不涉及可删除) 247 248| 参数名 | 类型 | 必填 | 说明 | 249| -------- | ------------------------------------ | ---- | ------------------------------------------------------------ | 250| type | string | 是 | 事件描述,需要说明触发时机。如一个方法涉及多个事件,需要分开说明。<br/>**示例1(单个):**<br/>事件回调类型,支持的事件为`'play'`,当`play()`调用完成,音频开始播放,触发该事件。<br/>**示例2(多个):**<br/>事件回调类型,支持的事件包括:`'play'` \| `'dataLoad' `\|`'finish'`。<br/>\- `'play'`:完成`play()`调用,音频开始播放,触发该事件。<br/>\- `'dataLoad'`:完成音频数据加载后触发该事件,即src属性设置完成后触发该事件。<br/>\- `'finish'`:完成音频播放后触发该事件。 | 251| callback | Callback\<[CustomType](#classinterface)> | 否 | 参数描述。与[方法](#方法)要求一致。 | 252 253**返回值:**(可选,如不涉及可删除) 254 255| 类型 | 说明 | 256| ------ | ------------------------------------- | 257| string | 返回值描述。与[方法](#方法)要求一致。 | 258 259**示例:** 260 261```js 262// 必选项。与方法要求一致。 263 264// 所有的示例代码需要进行自检。 265// 不能出现缺符号、变量前后不一致等低错。 266// 所有使用到的变量要进行声明。 267 268// 不允许直接写参数名,必须是可使用、易替代的实际用例。如果非用户自定义填写,需通过注释进行说明。 269// 例如:let result = xxx.createExample(parameterOne); // parameterOne由扫描自动获取 270 271// 注释要精简、突出要点。需提供注释的典型场景还有: 272// 1. 当代码不能说明变量命名的具体含义,或不能说明代码逻辑时,必须提供注释。 273// 2. 涉及到复杂算法或特殊语法时,必须提供注释。 274``` 275 276## Class/Interface 277 278> *写作说明* 279> 280> 1. 可选,如果没有可删除。如果有多个,请分多个二级内容描述,并使用“##”自行新建二级标题。 281> 282> 2. 二级标题名为class、interface的名称。 283> 284> 3. 如果该API中,既有属性,又有方法,需要先进行属性的写作,并使用“###”三级标题。 285> 如果该API中,只有属性,那么不需要新建三级标题,直接使用表格陈列属性。 286 287类描述/interface描述。如果有使用限制,需要在这个地方说明。比方说,是否有前提条件,是否需要通过什么方法先构造一个实例。 288 289### 属性 290 291> *写作说明* 292> 293> 除标题使用三级标题外,其余要求同[属性](#属性),如仅有属性,可删除“属性”小标题,直接写interface名称作为二级标题。 294 295### Class/Interface中的方法 296 297> *写作说明* 298> 299> 1. 标题名为方法名,使用**三级标题,没有前缀**。如果是订阅方法,需要在方法名加上对应的订阅事件。 300> 示例: getSimIccId 301> 订阅方法:on('exampleEvent') 302> 2. 其余与[方法](#方法)要求一致,不再重复。 303 304## 枚举 305 306> *写作说明* 307> 308> 1. 可选,如果没有可删除。如果有多个枚举,请分多个二级内容描述,并使用“##”自行新建二级标题。 309> 310> 2. 二级标题名为实际枚举名,比方说 BatteryHealthState 。 311 312在此处给出该枚举类型的简要描述。如:表示连接的充电器类型的枚举。 313 314**系统能力**:SystemCapability.xxx.xxx(必选) 315 316| 名称 | 值 | 说明 | 317| ---- | ---- | -------------------------- | 318| NONE | 1 | 表示连接的充电器类型未知。 | 319 320## Type 321 322> *写作说明* 323> 324> 1. 可选,如果没有可删除此二级标题,对应d.ts中的type定义。 325> 326> 2. 当前type分为两种情况,不同情况使用不同模板。 327> 328> - 当type为联合类型、交叉类型,其定义形如:type Xxx = number | string | 'xxx',或 type AB = InterfaceA & InterfaceB ,参考[模板一](#type模板一)。 329> - 当type的定义为某个函数、interface的别名,形如:type Xxx\<Aaa, Bbb> = (param1: number, param2: string) => void 或是 type Xxx = (param1: number, param2: string),按函数、interface的模板解释其参数,并在列表前给出type的定义,参考[模板二](#type模板二)。 330> 331> 3. 如果为取值范围为具体取值,如固定的字符串、枚举值等,需要说明其数据类型和指定取值;如果取值范围为指定类型,需说明是否取类型下任意值,还是有取值范围。 332> 333> 4. 类型如果为自定义类型,需要建立链接到对应的interface或enum中。 334 335 336### Type模板一 337 338type Xxx = number | string | 'xxx' 339 340在此处给出该类型的简要描述。如:表示允许的数据字段类型。 341 342在此处给出该类型实际取值的逻辑。如:取值类型为下表类型中的并集/交集。 343 344**系统能力**:SystemCapability.xxx.xxx(必选) 345 346| 类型 | 说明 | 347| -----------| ---------------------------- | 348| number | 表示值类型为数字,可取任意值。 | 349| string | 表示值类型为字符,可取任意值。 | 350| 'xxx' | 表示xxx(此处写值的含义),值固定为'xxx'字符串。 | 351 352### Type模板二 353 354*(此处以函数别名为例)* 355 356*(在此处给出type的具体定义形式)* type Xxx\<Aaa, Bbb> = (param1: number, param2: string) => Interface1 357 358**系统能力**:SystemCapability.xxx.xxx(必选) 359 360**参数:**(可选,如不涉及可删除) 361 362| 参数名 | 类型 | 必填 | 说明 | 363| -------- | ------------------------------------ | ---- | ------------------------------------------------------------ | 364| param1 | number | 是 | 参数描述。与[方法](#方法)要求一致。 | 365| param2 | string | 否 | 参数描述。与[方法](#方法)要求一致。 | 366 367**返回值:**(可选,如不涉及可删除) 368 369| 类型 | 说明 | 370| ------ | ------------------------------------- | 371| [Interface1](#interface1) | 返回值描述。与[方法](#方法)要求一致。 | 372 373### Type模板三 374 375*(此处以含有多个属性字段的Interface别名为例)* 376 377*(在此处给出type的具体定义形式)* type Xxx = { aaa: string; bbb?: number; } 378 379**系统能力**:SystemCapability.xxx.xxx(必选) 380 381 382| 名称 | 类型 | 必填 | 说明 | 383| -------- | ------------------------------------ | ---- | ------------------------------------------------------------ | 384| aaa | string | 是 | 属性描述。 | 385| bbb | number | 否 | 属性描述。 | 386 387## API参考写作FAQ 388### 问题1:带二级模块的父模块如何写作 389> **带二级模块的父模块写作要求:** 390> 391> 1、在模块概述处,写明本模块的定义/功能。 392> 393> 2、按正常API模块要求提供API level等相关说明。 394> 395> 3、以section列举其下包含的二级模块,并提供二级模块定义/功能(注意与二级模块页面的概述保持一致),链接到二级模块。 396> 397> 4、每个二级模块(section)下,提供d.ts定义中对应的“系统能力”(@syscap)字段。工具链基于该字段为该topic打device-type属性。 398> 399> 以下为样例。 400#### @ohos.arkui.node 401Node将自定义节点的二级模块API组织在一起,方便开发者进行导出使用。 402 403> **说明:** 404> 405> 本模块首批接口从API version 11开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 406> 407> 当前不支持在预览器中使用自定义节点。 408 409##### BuilderNode 410 411[BuilderNode](./js-apis-arkui-builderNode.md#buildernode)模块提供能够挂载系统组件的自定义节点BuilderNode。不建议将BuilderNode作为子节点挂载到其他自定义节点上。<br/> 412**系统能力**:ohos.xxx 413 414##### FrameNode 415 416[FrameNode](./js-apis-arkui-frameNode.md#framenode)模块提供自定义节点FrameNode,表示组件树的实体节点。[NodeController](./js-apis-arkui-nodeController.md#nodecontroller)可通过[BuilderNode](./js-apis-arkui-builderNode.md#buildernode)持有的FrameNode将其挂载到[NodeContainer](arkui-ts/ts-basic-components-nodecontainer.md#nodecontainer)上,也可通过FrameNode获取[RenderNode](./js-apis-arkui-renderNode.md#rendernode),挂载到其他FrameNode上。<br/> 417**系统能力**:ohos.xxx 418 419### 问题2:Class是继承的,只有一个导入模块,这种情况下的SysCap应该写在哪里 420> 421> 声明方式形如:[EmbeddableUIAbilityContext.d.ts](https://gitee.com/openharmony/interface_sdk-js/blob/master/api/application/EmbeddableUIAbilityContext.d.ts),参考如下样例写作。<br/> 422> 423 424#### EmbeddableUIAbilityContext 425 426EmbeddableUIAbilityContext是需要保存状态的[EmbeddableUIAbility](js-apis-app-ability-embeddableUIAbility.md)所对应的context,继承自[UIAbilityContext](js-apis-inner-application-uiAbilityContext.md)。<br/> 427EmbeddableUIAbilityContext提供EmbeddableUIAbility的相关配置信息以及操作EmbeddableUIAbility和ServiceExtensionAbility的方法,如启动EmbeddableUIAbility,停止当前EmbeddableUIAbilityContext所属的EmbeddableUIAbility,启动、停止、连接、断开连接ServiceExtensionAbility等。 428 429> **说明:** 430> 431> - 本模块首批接口从API version 12开始支持。后续版本的新增接口,采用上角标单独标记接口的起始版本。 432> - 本模块接口需要在主线程中使用,不要在Worker、TaskPool等子线程中使用。 433 434##### 导入模块 435 436```ts 437import { common } from '@kit.AbilityKit'; 438``` 439**模型约束**:此接口仅可在Stage模型下使用。<br/> 440**系统能力**:SystemCapability.Ability.AbilityRuntime.Core<br/> 441**原子化服务API**:从API version 12开始,该接口支持在原子化服务中使用。 442 443### 问题3:接口存在已知bug的写法 444> 445> 1、对于此类情况,首先需要在《版本说明书》中体现“已知问题”。 446> 447> 2、在API参考的“接口描述”处,采用固定句式描述接口已知bug"本接口存在已知问题,详情请参见“已知问题”。" 448> 449> 3、在接口bug修复后,针对所有涉及该接口的文档,统一搜索上述固定句式,删除。 450> 451#### getStringSync 452 453getStringSync(resId: number, ...args: Array<string | number>): string 454 455获取指定资源ID对应的字符串,并根据args参数对字符串进行格式化,使用同步方式返回。 456本接口存在已知问题,详情请参见“已知问题”(链接到《版本说明书》对应的已知问题处)。 457 458 459## 变更日志 460 461| 变更说明 | 日期 | 462| ----------------------------------------------------------------------- | ------------ | 463| 新增“API参考写作FAQ”章节,提供特殊场景的API参考写法及常见问题说明。 | 2025/07/22| 464| 精简Promise\<void>固定句式。新写作内容使用新句式;存量内容无需主动整改,表意无问题。 | 2025/06/10 | 465| 补充“关于匿名对象整改@since版本号情况的说明”固定句式。 | 2025/06/03 | 466| 优化权限的写作规范,可覆盖多种类型的权限描述,适配扫描工具需求。 | 2025/03/12 | 467| 增加Type模板三,增加以含有多个属性字段的Interface别名。 | 2025/03/04 | 468| 增加示例代码需捕获传参异常的要求。 | 2025/03/03 | 469| 针对const定义的只读变量,增加模板。 | 2024/12/31 | 470| 1. 修改方法模板,增加static等关键字声明的方法描述说明。 | 2024/05/16 | 471| 1. 修改Type模板,除原来的联合类型外,增加交叉类型,以及type作为函数、interface等别名的情况。<br/>2. 修改属性模板,仅针对interface和接口定义而言,明确规则,如果有?,则判定为“可选”。 | 2024/05/10 | 472| 1. 修改属性的模板,将“可读”、“可写”、“必填”,统一为“只读”、“必填”。<br/>2. 修改Type的模板,模板修改为“取值范围/说明”,并增加相关说明。<br/>3. 删除自定义类型,合并进class和interface的模板中。 | 2023/02/01 | 473| 1. 总体写作说明整理为表格。<br/>2. “图片路径”中,增加图片的引用方式说明。<br/>3. 增加“文档结构”,对文档各节点顺序进行说明。<br/>4. “权限说明”中,增加多权限的描述方式。<br/>5. 增加@FAModelOnly/@StageModelOnly标记在文档的描述方式。<br/>6. 增加异步接口说明(callback、Promise)。<br/>7. 增加示例代码语言的标准和规范。<br/>8. 增加文档链接的标准写法。<br/>9. 增加模块描述的固定句式、示例。<br/>10. 增加“on/off”等订阅方法的说明。<br/>11. 修改@syscap的描述方式,除表格内的差异项,其余保持一致。 <br/>12. 修改@systemapi的描述方式,仅保留“该系统为系统接口。”。<br/>13. 删除MR版本说明。 | 2022/6/24 | 474| 增加错误码说明。 | 2022/10/11 | 475| 1. 增加**常量const**、**类型type**的模板。<br/> 2. 修改自定义类型interface的表格,去除“可读、可写”,与d.ts保持一致,增加“必填”。<br/> 3. 针对同时存在起始版本和废弃版本的接口,增加废弃说明的模板。 |2022/11/22 | 476 477<!--no_check-->