1e41f4b71Sopenharmony_ci# OpenHarmony应用ArkTS编程规范 2e41f4b71Sopenharmony_ci 3e41f4b71Sopenharmony_ci# 概述 4e41f4b71Sopenharmony_ci 5e41f4b71Sopenharmony_ci## 目标和适用范围 6e41f4b71Sopenharmony_ci 7e41f4b71Sopenharmony_ci本文参考业界标准及实践,结合ArkTS语言特点,为提高代码的规范、安全、性能提供编码指南。 8e41f4b71Sopenharmony_ci 9e41f4b71Sopenharmony_ci本文适用于开发者进行系统开发或者应用开发时,使用ArkTS编写代码的场景。 10e41f4b71Sopenharmony_ci 11e41f4b71Sopenharmony_ci## 规则来源 12e41f4b71Sopenharmony_ci 13e41f4b71Sopenharmony_ciArkTS在保持TypeScript基本语法风格的基础上,进一步强化静态检查和分析。本文部分规则筛选自《[OpenHarmony应用TS&JS编程指南](OpenHarmony-Application-Typescript-JavaScript-coding-guide.md)》,为ArkTS语言新增的语法添加了规则,旨在提高代码可读性、执行性能。 14e41f4b71Sopenharmony_ci 15e41f4b71Sopenharmony_ci## 章节概览 16e41f4b71Sopenharmony_ci 17e41f4b71Sopenharmony_ci### 代码风格 18e41f4b71Sopenharmony_ci 19e41f4b71Sopenharmony_ci包含命名和格式。 20e41f4b71Sopenharmony_ci 21e41f4b71Sopenharmony_ci### 编程实践 22e41f4b71Sopenharmony_ci 23e41f4b71Sopenharmony_ci包含声明与初始化、数据类型、运算与表达式、异常等。 24e41f4b71Sopenharmony_ci 25e41f4b71Sopenharmony_ci参考了《OpenHarmony应用TS&JS编程指南》中的规则,对其中ArkTS语言不涉及的部分作了去除,为ArkTS语言新增的语法添加了规则。 26e41f4b71Sopenharmony_ci 27e41f4b71Sopenharmony_ci## 术语和定义 28e41f4b71Sopenharmony_ci 29e41f4b71Sopenharmony_ci| 术语 | 缩略语 | 中文解释 | 30e41f4b71Sopenharmony_ci| ---- | ---- | ----| 31e41f4b71Sopenharmony_ci| ArkTS | 无 | ArkTS编程语言 | 32e41f4b71Sopenharmony_ci| TypeScript | TS | TypeScript编程语言 | 33e41f4b71Sopenharmony_ci| JavaScript | JS | JavaScript编程语言 | 34e41f4b71Sopenharmony_ci| ESObject | 无 | 在ArkTS跨语言调用的场景中,用以标注JS/TS对象的类型 | 35e41f4b71Sopenharmony_ci 36e41f4b71Sopenharmony_ci# 总体原则 37e41f4b71Sopenharmony_ci 38e41f4b71Sopenharmony_ci规则分为两个级别:要求、建议。 39e41f4b71Sopenharmony_ci 40e41f4b71Sopenharmony_ci**要求**:表示原则上应该遵从。本文所有内容目前均为针对ArkTS的要求。 41e41f4b71Sopenharmony_ci 42e41f4b71Sopenharmony_ci**建议**:表示该条款属于最佳实践,可结合实际情况考虑是否纳入。 43e41f4b71Sopenharmony_ci 44e41f4b71Sopenharmony_ci# 命名 45e41f4b71Sopenharmony_ci 46e41f4b71Sopenharmony_ci## 为标识符取一个好名字,提高代码可读性 47e41f4b71Sopenharmony_ci 48e41f4b71Sopenharmony_ci**【描述】** 49e41f4b71Sopenharmony_ci 50e41f4b71Sopenharmony_ci好的标识符命名,应遵循以下基本原则: 51e41f4b71Sopenharmony_ci - 能清晰的表达意图,避免使用单个字母、未成惯例的缩写来命名 52e41f4b71Sopenharmony_ci - 使用正确的英文单词并符合英文语法,不要使用中文拼音 53e41f4b71Sopenharmony_ci - 能区分出意思,避免造成误导 54e41f4b71Sopenharmony_ci 55e41f4b71Sopenharmony_ci## 类名、枚举名、命名空间名采用UpperCamelCase风格 56e41f4b71Sopenharmony_ci 57e41f4b71Sopenharmony_ci**【级别】建议** 58e41f4b71Sopenharmony_ci 59e41f4b71Sopenharmony_ci**【描述】** 60e41f4b71Sopenharmony_ci 61e41f4b71Sopenharmony_ci类采用首字母大写的驼峰命名法。 62e41f4b71Sopenharmony_ci类名通常是名词或名词短语,例如Person、Student、Worker。不应使用动词,也应该避免类似Data、Info这样的模糊词。 63e41f4b71Sopenharmony_ci 64e41f4b71Sopenharmony_ci**【正例】** 65e41f4b71Sopenharmony_ci``` 66e41f4b71Sopenharmony_ci// 类名 67e41f4b71Sopenharmony_ciclass User { 68e41f4b71Sopenharmony_ci username: string 69e41f4b71Sopenharmony_ci 70e41f4b71Sopenharmony_ci constructor(username: string) { 71e41f4b71Sopenharmony_ci this.username = username; 72e41f4b71Sopenharmony_ci } 73e41f4b71Sopenharmony_ci 74e41f4b71Sopenharmony_ci sayHi() { 75e41f4b71Sopenharmony_ci console.log('hi' + this.username); 76e41f4b71Sopenharmony_ci } 77e41f4b71Sopenharmony_ci} 78e41f4b71Sopenharmony_ci 79e41f4b71Sopenharmony_ci// 枚举名 80e41f4b71Sopenharmony_cienum UserType { 81e41f4b71Sopenharmony_ci TEACHER = 0, 82e41f4b71Sopenharmony_ci STUDENT = 1 83e41f4b71Sopenharmony_ci}; 84e41f4b71Sopenharmony_ci 85e41f4b71Sopenharmony_ci// 命名空间 86e41f4b71Sopenharmony_cinamespace Base64Utils { 87e41f4b71Sopenharmony_ci function encrypt() { 88e41f4b71Sopenharmony_ci // todo encrypt 89e41f4b71Sopenharmony_ci } 90e41f4b71Sopenharmony_ci 91e41f4b71Sopenharmony_ci function decrypt() { 92e41f4b71Sopenharmony_ci // todo decrypt 93e41f4b71Sopenharmony_ci } 94e41f4b71Sopenharmony_ci}; 95e41f4b71Sopenharmony_ci``` 96e41f4b71Sopenharmony_ci 97e41f4b71Sopenharmony_ci## 变量名、方法名、参数名采用lowerCamelCase风格 98e41f4b71Sopenharmony_ci 99e41f4b71Sopenharmony_ci**【级别】建议** 100e41f4b71Sopenharmony_ci 101e41f4b71Sopenharmony_ci**【描述】** 102e41f4b71Sopenharmony_ci 103e41f4b71Sopenharmony_ci函数的命名通常是动词或动词短语,采用小驼峰命名,示例如下: 104e41f4b71Sopenharmony_ci1. load + 属性名() 105e41f4b71Sopenharmony_ci2. put + 属性名() 106e41f4b71Sopenharmony_ci3. is + 布尔属性名() 107e41f4b71Sopenharmony_ci4. has + 名词/形容词() 108e41f4b71Sopenharmony_ci5. 动词() 109e41f4b71Sopenharmony_ci6. 动词 + 宾语() 110e41f4b71Sopenharmony_ci变量的名字通常是名词或名词短语,应采用小驼峰命名,以便于理解其含义。 111e41f4b71Sopenharmony_ci 112e41f4b71Sopenharmony_ci**【正例】** 113e41f4b71Sopenharmony_ci``` 114e41f4b71Sopenharmony_cilet msg = 'Hello world'; 115e41f4b71Sopenharmony_ci 116e41f4b71Sopenharmony_cifunction sendMsg(msg: string) { 117e41f4b71Sopenharmony_ci // todo send message 118e41f4b71Sopenharmony_ci} 119e41f4b71Sopenharmony_ci 120e41f4b71Sopenharmony_cilet userName = 'Zhangsan'; 121e41f4b71Sopenharmony_ci 122e41f4b71Sopenharmony_cifunction findUser(userName: string) { 123e41f4b71Sopenharmony_ci // todo find user by user name 124e41f4b71Sopenharmony_ci} 125e41f4b71Sopenharmony_ci``` 126e41f4b71Sopenharmony_ci 127e41f4b71Sopenharmony_ci## 常量名、枚举值名采用全部大写,单词间使用下划线隔开 128e41f4b71Sopenharmony_ci 129e41f4b71Sopenharmony_ci**【级别】建议** 130e41f4b71Sopenharmony_ci 131e41f4b71Sopenharmony_ci**【描述】** 132e41f4b71Sopenharmony_ci 133e41f4b71Sopenharmony_ci常量命名,应该由全大写单词与下划线组成,单词间用下划线分割。常量命名要尽量表达完整的语义。 134e41f4b71Sopenharmony_ci 135e41f4b71Sopenharmony_ci**【正例】** 136e41f4b71Sopenharmony_ci 137e41f4b71Sopenharmony_ci``` 138e41f4b71Sopenharmony_ciconst MAX_USER_SIZE = 10000; 139e41f4b71Sopenharmony_ci 140e41f4b71Sopenharmony_cienum UserType { 141e41f4b71Sopenharmony_ci TEACHER = 0, 142e41f4b71Sopenharmony_ci STUDENT = 1 143e41f4b71Sopenharmony_ci}; 144e41f4b71Sopenharmony_ci``` 145e41f4b71Sopenharmony_ci 146e41f4b71Sopenharmony_ci## 避免使用否定的布尔变量名,布尔型的局部变量或方法须加上表达是非意义的前缀 147e41f4b71Sopenharmony_ci 148e41f4b71Sopenharmony_ci**【级别】建议** 149e41f4b71Sopenharmony_ci 150e41f4b71Sopenharmony_ci**【描述】** 151e41f4b71Sopenharmony_ci 152e41f4b71Sopenharmony_ci布尔型的局部变量建议加上表达是非意义的前缀,比如is,也可以是has、can、should等。但是,当使用逻辑非运算符,并出现双重否定时,会出现理解问题,比如!isNotError,意味着什么,不是很好理解。因此,应避免定义否定的布尔变量名。 153e41f4b71Sopenharmony_ci 154e41f4b71Sopenharmony_ci**【反例】** 155e41f4b71Sopenharmony_ci 156e41f4b71Sopenharmony_ci``` 157e41f4b71Sopenharmony_cilet isNoError = true; 158e41f4b71Sopenharmony_cilet isNotFound = false; 159e41f4b71Sopenharmony_ci 160e41f4b71Sopenharmony_cifunction empty() {} 161e41f4b71Sopenharmony_cifunction next() {} 162e41f4b71Sopenharmony_ci``` 163e41f4b71Sopenharmony_ci 164e41f4b71Sopenharmony_ci**【正例】** 165e41f4b71Sopenharmony_ci 166e41f4b71Sopenharmony_ci``` 167e41f4b71Sopenharmony_cilet isError = false; 168e41f4b71Sopenharmony_cilet isFound = true; 169e41f4b71Sopenharmony_ci 170e41f4b71Sopenharmony_cifunction isEmpty() {} 171e41f4b71Sopenharmony_cifunction hasNext() {} 172e41f4b71Sopenharmony_ci``` 173e41f4b71Sopenharmony_ci 174e41f4b71Sopenharmony_ci# 格式 175e41f4b71Sopenharmony_ci 176e41f4b71Sopenharmony_ci## 使用空格缩进,禁止使用tab字符 177e41f4b71Sopenharmony_ci 178e41f4b71Sopenharmony_ci**【级别】建议** 179e41f4b71Sopenharmony_ci 180e41f4b71Sopenharmony_ci**【描述】** 181e41f4b71Sopenharmony_ci 182e41f4b71Sopenharmony_ci只允许使用空格(space)进行缩进。 183e41f4b71Sopenharmony_ci 184e41f4b71Sopenharmony_ci建议大部分场景优先使用2个空格,换行导致的缩进优先使用4个空格。 185e41f4b71Sopenharmony_ci不允许插入制表符Tab。当前几乎所有的集成开发环境(IDE)和代码编辑器都支持配置将Tab键自动扩展为2个空格输入,应在代码编辑器中配置使用空格进行缩进。 186e41f4b71Sopenharmony_ci 187e41f4b71Sopenharmony_ci**【正例】** 188e41f4b71Sopenharmony_ci 189e41f4b71Sopenharmony_ci``` 190e41f4b71Sopenharmony_ciclass DataSource { 191e41f4b71Sopenharmony_ci id: number = 0 192e41f4b71Sopenharmony_ci title: string = '' 193e41f4b71Sopenharmony_ci content: string = '' 194e41f4b71Sopenharmony_ci} 195e41f4b71Sopenharmony_ci 196e41f4b71Sopenharmony_ciconst dataSource: DataSource[] = [ 197e41f4b71Sopenharmony_ci { 198e41f4b71Sopenharmony_ci id: 1, 199e41f4b71Sopenharmony_ci title: 'Title 1', 200e41f4b71Sopenharmony_ci content: 'Content 1' 201e41f4b71Sopenharmony_ci }, 202e41f4b71Sopenharmony_ci { 203e41f4b71Sopenharmony_ci id: 2, 204e41f4b71Sopenharmony_ci title: 'Title 2', 205e41f4b71Sopenharmony_ci content: 'Content 2' 206e41f4b71Sopenharmony_ci } 207e41f4b71Sopenharmony_ci 208e41f4b71Sopenharmony_ci]; 209e41f4b71Sopenharmony_ci 210e41f4b71Sopenharmony_cifunction test(dataSource: DataSource[]) { 211e41f4b71Sopenharmony_ci if (!dataSource.length) { 212e41f4b71Sopenharmony_ci return; 213e41f4b71Sopenharmony_ci } 214e41f4b71Sopenharmony_ci 215e41f4b71Sopenharmony_ci for (let data of dataSource) { 216e41f4b71Sopenharmony_ci if (!data || !data.id || !data.title || !data.content) { 217e41f4b71Sopenharmony_ci continue; 218e41f4b71Sopenharmony_ci } 219e41f4b71Sopenharmony_ci // some code 220e41f4b71Sopenharmony_ci } 221e41f4b71Sopenharmony_ci 222e41f4b71Sopenharmony_ci // some code 223e41f4b71Sopenharmony_ci} 224e41f4b71Sopenharmony_ci``` 225e41f4b71Sopenharmony_ci 226e41f4b71Sopenharmony_ci## 行宽不超过120个字符 227e41f4b71Sopenharmony_ci 228e41f4b71Sopenharmony_ci**【级别】建议** 229e41f4b71Sopenharmony_ci 230e41f4b71Sopenharmony_ci**【描述】** 231e41f4b71Sopenharmony_ci 232e41f4b71Sopenharmony_ci代码行宽不宜过长,否则不利于阅读。 233e41f4b71Sopenharmony_ci 234e41f4b71Sopenharmony_ci控制行宽可以间接的引导程序员去缩短函数、变量的命名,减少嵌套的层数,精炼注释,提升代码可读性。 235e41f4b71Sopenharmony_ci建议每行字符数不要超过120个;除非超过120能显著增加可读性,并且不会隐藏信息。 236e41f4b71Sopenharmony_ci例外:如果一行注释包含了超过120个字符的命令或URL,则可以保持一行,以方便复制、粘贴和通过grep查找;预处理的error信息在一行便于阅读和理解,即使超过120个字符。 237e41f4b71Sopenharmony_ci 238e41f4b71Sopenharmony_ci## 条件语句和循环语句的实现必须使用大括号 239e41f4b71Sopenharmony_ci 240e41f4b71Sopenharmony_ci**【级别】建议** 241e41f4b71Sopenharmony_ci 242e41f4b71Sopenharmony_ci**【描述】** 243e41f4b71Sopenharmony_ci 244e41f4b71Sopenharmony_ci在`if`、`for`、`do`、`while`等语句的执行体加大括号`{}`是一种最佳实践,因为省略大括号容易导致错误,并且降低代码的清晰度。 245e41f4b71Sopenharmony_ci 246e41f4b71Sopenharmony_ci**【反例】** 247e41f4b71Sopenharmony_ci 248e41f4b71Sopenharmony_ci``` 249e41f4b71Sopenharmony_ciif (condition) 250e41f4b71Sopenharmony_ci console.log('success'); 251e41f4b71Sopenharmony_ci 252e41f4b71Sopenharmony_cifor (let idx = 0; idx < 5; ++idx) 253e41f4b71Sopenharmony_ci console.log(idx); 254e41f4b71Sopenharmony_ci``` 255e41f4b71Sopenharmony_ci 256e41f4b71Sopenharmony_ci**【正例】** 257e41f4b71Sopenharmony_ci 258e41f4b71Sopenharmony_ci``` 259e41f4b71Sopenharmony_ciif (condition) { 260e41f4b71Sopenharmony_ci console.log('success'); 261e41f4b71Sopenharmony_ci} 262e41f4b71Sopenharmony_ci 263e41f4b71Sopenharmony_cifor (let idx = 0; idx < 5; ++idx) { 264e41f4b71Sopenharmony_ci console.log(idx); 265e41f4b71Sopenharmony_ci} 266e41f4b71Sopenharmony_ci``` 267e41f4b71Sopenharmony_ci 268e41f4b71Sopenharmony_ci## `switch`语句的`case`和`default`须缩进一层 269e41f4b71Sopenharmony_ci 270e41f4b71Sopenharmony_ci**【级别】建议** 271e41f4b71Sopenharmony_ci 272e41f4b71Sopenharmony_ci**【描述】** 273e41f4b71Sopenharmony_ci 274e41f4b71Sopenharmony_ci`switch`的`case`和`default`要缩进一层(2个空格)。开关标签之后换行的语句,需再缩进一层(2个空格)。 275e41f4b71Sopenharmony_ci 276e41f4b71Sopenharmony_ci**【正例】** 277e41f4b71Sopenharmony_ci 278e41f4b71Sopenharmony_ci``` 279e41f4b71Sopenharmony_ciswitch (condition) { 280e41f4b71Sopenharmony_ci case 0: { 281e41f4b71Sopenharmony_ci doSomething(); 282e41f4b71Sopenharmony_ci break; 283e41f4b71Sopenharmony_ci } 284e41f4b71Sopenharmony_ci case 1: { 285e41f4b71Sopenharmony_ci doOtherthing(); 286e41f4b71Sopenharmony_ci break; 287e41f4b71Sopenharmony_ci } 288e41f4b71Sopenharmony_ci default: 289e41f4b71Sopenharmony_ci break; 290e41f4b71Sopenharmony_ci} 291e41f4b71Sopenharmony_ci``` 292e41f4b71Sopenharmony_ci 293e41f4b71Sopenharmony_ci## 表达式换行须保持一致性,运算符放行末 294e41f4b71Sopenharmony_ci 295e41f4b71Sopenharmony_ci**【级别】建议** 296e41f4b71Sopenharmony_ci 297e41f4b71Sopenharmony_ci**【描述】** 298e41f4b71Sopenharmony_ci 299e41f4b71Sopenharmony_ci当语句过长,或者可读性不佳时,需要在合适的地方换行。 300e41f4b71Sopenharmony_ci换行时将操作符放在行末,表示“未结束,后续还有”,保持与常用的格式化工具的默认配置一致。 301e41f4b71Sopenharmony_ci 302e41f4b71Sopenharmony_ci**【正例】** 303e41f4b71Sopenharmony_ci 304e41f4b71Sopenharmony_ci``` 305e41f4b71Sopenharmony_ci// 假设条件语句超出行宽 306e41f4b71Sopenharmony_ciif (userCount > MAX_USER_COUNT || 307e41f4b71Sopenharmony_ci userCount < MIN_USER_COUNT) { 308e41f4b71Sopenharmony_ci doSomething(); 309e41f4b71Sopenharmony_ci} 310e41f4b71Sopenharmony_ci``` 311e41f4b71Sopenharmony_ci 312e41f4b71Sopenharmony_ci## 多个变量定义和赋值语句不允许写在一行 313e41f4b71Sopenharmony_ci 314e41f4b71Sopenharmony_ci**【级别】要求** 315e41f4b71Sopenharmony_ci 316e41f4b71Sopenharmony_ci**【描述】** 317e41f4b71Sopenharmony_ci 318e41f4b71Sopenharmony_ci每个语句的变量声明都应只声明一个变量。 319e41f4b71Sopenharmony_ci这种方式更易添加变量声明,不用考虑将`;`变成`,`,以免引入错误。另外,每个语句只声明一个变量,用debugger逐个调试也很方便,而不是一次跳过所有变量。 320e41f4b71Sopenharmony_ci 321e41f4b71Sopenharmony_ci**【反例】** 322e41f4b71Sopenharmony_ci 323e41f4b71Sopenharmony_ci``` 324e41f4b71Sopenharmony_cilet maxCount = 10, isCompleted = false; 325e41f4b71Sopenharmony_cilet pointX, pointY; 326e41f4b71Sopenharmony_cipointX = 10; pointY = 0; 327e41f4b71Sopenharmony_ci``` 328e41f4b71Sopenharmony_ci 329e41f4b71Sopenharmony_ci**【正例】** 330e41f4b71Sopenharmony_ci 331e41f4b71Sopenharmony_ci``` 332e41f4b71Sopenharmony_cilet maxCount = 10; 333e41f4b71Sopenharmony_cilet isCompleted = false; 334e41f4b71Sopenharmony_cilet pointX = 0; 335e41f4b71Sopenharmony_cilet pointY = 0; 336e41f4b71Sopenharmony_ci``` 337e41f4b71Sopenharmony_ci 338e41f4b71Sopenharmony_ci## 空格应该突出关键字和重要信息,避免不必要的空格 339e41f4b71Sopenharmony_ci 340e41f4b71Sopenharmony_ci**【级别】建议** 341e41f4b71Sopenharmony_ci 342e41f4b71Sopenharmony_ci**【描述】** 343e41f4b71Sopenharmony_ci 344e41f4b71Sopenharmony_ci空格应该突出关键字和重要信息。总体建议如下: 345e41f4b71Sopenharmony_ci1. `if`, `for`, `while`, `switch`等关键字与左括号`(`之间加空格。 346e41f4b71Sopenharmony_ci2. 在函数定义和调用时,函数名称与参数列表的左括号`(`之间不加空格。 347e41f4b71Sopenharmony_ci3. 关键字`else`或`catch`与其之前的大括号`}`之间加空格。 348e41f4b71Sopenharmony_ci4. 任何打开大括号(`{`)之前加空格,有两个例外: 349e41f4b71Sopenharmony_cia) 在作为函数的第一个参数或数组中的第一个元素时,对象之前不用加空格,例如:`foo({ name: 'abc' })`。 350e41f4b71Sopenharmony_cib) 在模板中,不用加空格,例如:`abc${name}`。 351e41f4b71Sopenharmony_ci5. 二元操作符(`+` `-` `*` `=` `<` `>` `<=` `>=` `===` `!==` `&&` `||`)前后加空格;三元操作符(`? :`)符号两侧均加空格。 352e41f4b71Sopenharmony_ci6. 数组初始化中的逗号和函数中多个参数之间的逗号后加空格。 353e41f4b71Sopenharmony_ci7. 在逗号(`,`)或分号(`;`)之前不加空格。 354e41f4b71Sopenharmony_ci8. 数组的中括号(`[]`)内侧不要加空格。 355e41f4b71Sopenharmony_ci9. 不要出现多个连续空格。在某行中,多个空格若不是用来作缩进的,通常是个错误。 356e41f4b71Sopenharmony_ci 357e41f4b71Sopenharmony_ci**【反例】** 358e41f4b71Sopenharmony_ci 359e41f4b71Sopenharmony_ci``` 360e41f4b71Sopenharmony_ci// if 和左括号 ( 之间没有加空格 361e41f4b71Sopenharmony_ciif(isJedi) { 362e41f4b71Sopenharmony_ci fight(); 363e41f4b71Sopenharmony_ci} 364e41f4b71Sopenharmony_ci 365e41f4b71Sopenharmony_ci// 函数名fight和左括号 ( 之间加了空格 366e41f4b71Sopenharmony_cifunction fight (): void { 367e41f4b71Sopenharmony_ci console.log('Swooosh!'); 368e41f4b71Sopenharmony_ci} 369e41f4b71Sopenharmony_ci``` 370e41f4b71Sopenharmony_ci 371e41f4b71Sopenharmony_ci**【正例】** 372e41f4b71Sopenharmony_ci 373e41f4b71Sopenharmony_ci``` 374e41f4b71Sopenharmony_ci// if 和左括号之间加一个空格 375e41f4b71Sopenharmony_ciif (isJedi) { 376e41f4b71Sopenharmony_ci fight(); 377e41f4b71Sopenharmony_ci} 378e41f4b71Sopenharmony_ci 379e41f4b71Sopenharmony_ci// 函数名fight和左括号 ( 之间不加空格 380e41f4b71Sopenharmony_cifunction fight(): void { 381e41f4b71Sopenharmony_ci console.log('Swooosh!'); 382e41f4b71Sopenharmony_ci} 383e41f4b71Sopenharmony_ci``` 384e41f4b71Sopenharmony_ci 385e41f4b71Sopenharmony_ci**【反例】** 386e41f4b71Sopenharmony_ci 387e41f4b71Sopenharmony_ci``` 388e41f4b71Sopenharmony_ciif (flag) { 389e41f4b71Sopenharmony_ci //... 390e41f4b71Sopenharmony_ci}else { // else 与其前面的大括号 } 之间没有加空格 391e41f4b71Sopenharmony_ci //... 392e41f4b71Sopenharmony_ci} 393e41f4b71Sopenharmony_ci``` 394e41f4b71Sopenharmony_ci 395e41f4b71Sopenharmony_ci**【正例】** 396e41f4b71Sopenharmony_ci 397e41f4b71Sopenharmony_ci``` 398e41f4b71Sopenharmony_ciif (flag) { 399e41f4b71Sopenharmony_ci //... 400e41f4b71Sopenharmony_ci} else { // else 与其前面的大括号 } 之间增加空格 401e41f4b71Sopenharmony_ci //... 402e41f4b71Sopenharmony_ci} 403e41f4b71Sopenharmony_ci``` 404e41f4b71Sopenharmony_ci 405e41f4b71Sopenharmony_ci**【正例】** 406e41f4b71Sopenharmony_ci 407e41f4b71Sopenharmony_ci``` 408e41f4b71Sopenharmony_cifunction foo() { // 函数声明时,左大括号 { 之前加个空格 409e41f4b71Sopenharmony_ci //... 410e41f4b71Sopenharmony_ci} 411e41f4b71Sopenharmony_ci 412e41f4b71Sopenharmony_cibar('attr', { // 左大括号前加个空格 413e41f4b71Sopenharmony_ci age: '1 year', 414e41f4b71Sopenharmony_ci sbreed: 'Bernese Mountain Dog', 415e41f4b71Sopenharmony_ci}); 416e41f4b71Sopenharmony_ci``` 417e41f4b71Sopenharmony_ci 418e41f4b71Sopenharmony_ci**【正例】** 419e41f4b71Sopenharmony_ci 420e41f4b71Sopenharmony_ci``` 421e41f4b71Sopenharmony_ciconst arr = [1, 2, 3]; // 数组初始化中的逗号后面加个空格,逗号前面不加空格 422e41f4b71Sopenharmony_cimyFunc(bar, foo, baz); // 函数的多个参数之间的逗号后加个空格,逗号前面不加空格 423e41f4b71Sopenharmony_ci``` 424e41f4b71Sopenharmony_ci 425e41f4b71Sopenharmony_ci## 建议字符串使用单引号 426e41f4b71Sopenharmony_ci 427e41f4b71Sopenharmony_ci**【级别】建议** 428e41f4b71Sopenharmony_ci 429e41f4b71Sopenharmony_ci**【描述】** 430e41f4b71Sopenharmony_ci 431e41f4b71Sopenharmony_ci较为约定俗成,单引号优于双引号。 432e41f4b71Sopenharmony_ci 433e41f4b71Sopenharmony_ci**【反例】** 434e41f4b71Sopenharmony_ci 435e41f4b71Sopenharmony_ci``` 436e41f4b71Sopenharmony_cilet message = "world"; 437e41f4b71Sopenharmony_ciconsole.log(message); 438e41f4b71Sopenharmony_ci``` 439e41f4b71Sopenharmony_ci 440e41f4b71Sopenharmony_ci**【正例】** 441e41f4b71Sopenharmony_ci 442e41f4b71Sopenharmony_ci``` 443e41f4b71Sopenharmony_cilet message = 'world'; 444e41f4b71Sopenharmony_ciconsole.log(message); 445e41f4b71Sopenharmony_ci``` 446e41f4b71Sopenharmony_ci 447e41f4b71Sopenharmony_ci## 对象字面量属性超过4个,需要都换行 448e41f4b71Sopenharmony_ci 449e41f4b71Sopenharmony_ci**【级别】建议** 450e41f4b71Sopenharmony_ci 451e41f4b71Sopenharmony_ci**【描述】** 452e41f4b71Sopenharmony_ci 453e41f4b71Sopenharmony_ci对象字面量要么每个属性都换行,要么所有属性都在同一行。当对象字面量属性超过4个的时候,建议统一换行。 454e41f4b71Sopenharmony_ci 455e41f4b71Sopenharmony_ci**【反例】** 456e41f4b71Sopenharmony_ci 457e41f4b71Sopenharmony_ci``` 458e41f4b71Sopenharmony_ciinterface I { 459e41f4b71Sopenharmony_ci name: string 460e41f4b71Sopenharmony_ci age: number 461e41f4b71Sopenharmony_ci value: number 462e41f4b71Sopenharmony_ci sum: number 463e41f4b71Sopenharmony_ci foo: boolean 464e41f4b71Sopenharmony_ci bar: boolean 465e41f4b71Sopenharmony_ci} 466e41f4b71Sopenharmony_ci 467e41f4b71Sopenharmony_cilet obj: I = { name: 'tom', age: 16, value: 1, sum: 2, foo: true, bar: false } 468e41f4b71Sopenharmony_ci``` 469e41f4b71Sopenharmony_ci 470e41f4b71Sopenharmony_ci**【正例】** 471e41f4b71Sopenharmony_ci 472e41f4b71Sopenharmony_ci``` 473e41f4b71Sopenharmony_ciinterface I { 474e41f4b71Sopenharmony_ci name: string 475e41f4b71Sopenharmony_ci age: number 476e41f4b71Sopenharmony_ci value: number 477e41f4b71Sopenharmony_ci sum: number 478e41f4b71Sopenharmony_ci foo: boolean 479e41f4b71Sopenharmony_ci bar: boolean 480e41f4b71Sopenharmony_ci} 481e41f4b71Sopenharmony_ci 482e41f4b71Sopenharmony_cilet obj: I = { 483e41f4b71Sopenharmony_ci name: 'tom', 484e41f4b71Sopenharmony_ci age: 16, 485e41f4b71Sopenharmony_ci value: 1, 486e41f4b71Sopenharmony_ci sum: 2, 487e41f4b71Sopenharmony_ci foo: true, 488e41f4b71Sopenharmony_ci bar: false 489e41f4b71Sopenharmony_ci} 490e41f4b71Sopenharmony_ci``` 491e41f4b71Sopenharmony_ci 492e41f4b71Sopenharmony_ci## 把`else`/`catch`放在`if`/`try`代码块关闭括号的同一行 493e41f4b71Sopenharmony_ci 494e41f4b71Sopenharmony_ci**【级别】建议** 495e41f4b71Sopenharmony_ci 496e41f4b71Sopenharmony_ci**【描述】** 497e41f4b71Sopenharmony_ci 498e41f4b71Sopenharmony_ci在写条件语句时,建议把`else`放在`if`代码块关闭括号的同一行。同样,在写异常处理语句时,建议把`catch`也放在`try`代码块关闭括号的同一行。 499e41f4b71Sopenharmony_ci 500e41f4b71Sopenharmony_ci**【反例】** 501e41f4b71Sopenharmony_ci 502e41f4b71Sopenharmony_ci``` 503e41f4b71Sopenharmony_ciif (isOk) { 504e41f4b71Sopenharmony_ci doThing1(); 505e41f4b71Sopenharmony_ci doThing2(); 506e41f4b71Sopenharmony_ci} 507e41f4b71Sopenharmony_cielse { 508e41f4b71Sopenharmony_ci doThing3(); 509e41f4b71Sopenharmony_ci} 510e41f4b71Sopenharmony_ci``` 511e41f4b71Sopenharmony_ci 512e41f4b71Sopenharmony_ci**【正例】** 513e41f4b71Sopenharmony_ci 514e41f4b71Sopenharmony_ci``` 515e41f4b71Sopenharmony_ciif (isOk) { 516e41f4b71Sopenharmony_ci doThing1(); 517e41f4b71Sopenharmony_ci doThing2(); 518e41f4b71Sopenharmony_ci} else { 519e41f4b71Sopenharmony_ci doThing3(); 520e41f4b71Sopenharmony_ci} 521e41f4b71Sopenharmony_ci``` 522e41f4b71Sopenharmony_ci 523e41f4b71Sopenharmony_ci**【反例】** 524e41f4b71Sopenharmony_ci 525e41f4b71Sopenharmony_ci``` 526e41f4b71Sopenharmony_citry { 527e41f4b71Sopenharmony_ci doSomething(); 528e41f4b71Sopenharmony_ci} 529e41f4b71Sopenharmony_cicatch (err) { 530e41f4b71Sopenharmony_ci // 处理错误 531e41f4b71Sopenharmony_ci} 532e41f4b71Sopenharmony_ci``` 533e41f4b71Sopenharmony_ci 534e41f4b71Sopenharmony_ci**【正例】** 535e41f4b71Sopenharmony_ci 536e41f4b71Sopenharmony_ci``` 537e41f4b71Sopenharmony_citry { 538e41f4b71Sopenharmony_ci doSomething(); 539e41f4b71Sopenharmony_ci} catch (err) { 540e41f4b71Sopenharmony_ci // 处理错误 541e41f4b71Sopenharmony_ci} 542e41f4b71Sopenharmony_ci``` 543e41f4b71Sopenharmony_ci 544e41f4b71Sopenharmony_ci## 大括号`{`和语句在同一行 545e41f4b71Sopenharmony_ci 546e41f4b71Sopenharmony_ci**【级别】建议** 547e41f4b71Sopenharmony_ci 548e41f4b71Sopenharmony_ci**【描述】** 549e41f4b71Sopenharmony_ci 550e41f4b71Sopenharmony_ci应保持一致的大括号风格。建议将大括号放在控制语句或声明语句同一行的位置。 551e41f4b71Sopenharmony_ci 552e41f4b71Sopenharmony_ci**【反例】** 553e41f4b71Sopenharmony_ci 554e41f4b71Sopenharmony_ci``` 555e41f4b71Sopenharmony_cifunction foo() 556e41f4b71Sopenharmony_ci{ 557e41f4b71Sopenharmony_ci //... 558e41f4b71Sopenharmony_ci} 559e41f4b71Sopenharmony_ci``` 560e41f4b71Sopenharmony_ci 561e41f4b71Sopenharmony_ci**【正例】** 562e41f4b71Sopenharmony_ci 563e41f4b71Sopenharmony_ci``` 564e41f4b71Sopenharmony_cifunction foo() { 565e41f4b71Sopenharmony_ci //... 566e41f4b71Sopenharmony_ci} 567e41f4b71Sopenharmony_ci``` 568e41f4b71Sopenharmony_ci 569e41f4b71Sopenharmony_ci# 编程实践 570e41f4b71Sopenharmony_ci 571e41f4b71Sopenharmony_ci## 建议添加类属性的可访问修饰符 572e41f4b71Sopenharmony_ci 573e41f4b71Sopenharmony_ci**【级别】建议** 574e41f4b71Sopenharmony_ci 575e41f4b71Sopenharmony_ci**【描述】** 576e41f4b71Sopenharmony_ci 577e41f4b71Sopenharmony_ci在ArkTS中,提供了`private`, `protected`和`public`可访问修饰符。默认情况下一个属性的可访问修饰符为`public`。选取适当的可访问修饰符可以提升代码的安全性、可读性。注意:如果类中包含`private`属性,无法通过对象字面量初始化该类。 578e41f4b71Sopenharmony_ci 579e41f4b71Sopenharmony_ci**【反例】** 580e41f4b71Sopenharmony_ci 581e41f4b71Sopenharmony_ci``` 582e41f4b71Sopenharmony_ciclass C { 583e41f4b71Sopenharmony_ci count: number = 0 584e41f4b71Sopenharmony_ci 585e41f4b71Sopenharmony_ci getCount(): number { 586e41f4b71Sopenharmony_ci return this.count 587e41f4b71Sopenharmony_ci } 588e41f4b71Sopenharmony_ci} 589e41f4b71Sopenharmony_ci``` 590e41f4b71Sopenharmony_ci 591e41f4b71Sopenharmony_ci**【正例】** 592e41f4b71Sopenharmony_ci 593e41f4b71Sopenharmony_ci``` 594e41f4b71Sopenharmony_ciclass C { 595e41f4b71Sopenharmony_ci private count: number = 0 596e41f4b71Sopenharmony_ci 597e41f4b71Sopenharmony_ci public getCount(): number { 598e41f4b71Sopenharmony_ci return this.count 599e41f4b71Sopenharmony_ci } 600e41f4b71Sopenharmony_ci} 601e41f4b71Sopenharmony_ci``` 602e41f4b71Sopenharmony_ci 603e41f4b71Sopenharmony_ci## 不建议省略浮点数小数点前后的0 604e41f4b71Sopenharmony_ci 605e41f4b71Sopenharmony_ci**【级别】建议** 606e41f4b71Sopenharmony_ci 607e41f4b71Sopenharmony_ci**【描述】** 608e41f4b71Sopenharmony_ci 609e41f4b71Sopenharmony_ci在ArkTS中,浮点值会包含一个小数点,没有要求小数点之前或之后必须有一个数字。在小数点前面和后面均添加数字可以提高代码可读性。 610e41f4b71Sopenharmony_ci 611e41f4b71Sopenharmony_ci**【反例】** 612e41f4b71Sopenharmony_ci 613e41f4b71Sopenharmony_ci``` 614e41f4b71Sopenharmony_ciconst num = .5; 615e41f4b71Sopenharmony_ciconst num = 2.; 616e41f4b71Sopenharmony_ciconst num = -.7; 617e41f4b71Sopenharmony_ci``` 618e41f4b71Sopenharmony_ci 619e41f4b71Sopenharmony_ci**【正例】** 620e41f4b71Sopenharmony_ci 621e41f4b71Sopenharmony_ci``` 622e41f4b71Sopenharmony_ciconst num = 0.5; 623e41f4b71Sopenharmony_ciconst num = 2.0; 624e41f4b71Sopenharmony_ciconst num = -0.7; 625e41f4b71Sopenharmony_ci``` 626e41f4b71Sopenharmony_ci 627e41f4b71Sopenharmony_ci## 判断变量是否为`Number.NaN`时必须使用`Number.isNaN()`方法 628e41f4b71Sopenharmony_ci 629e41f4b71Sopenharmony_ci**【级别】要求** 630e41f4b71Sopenharmony_ci 631e41f4b71Sopenharmony_ci**【描述】** 632e41f4b71Sopenharmony_ci 633e41f4b71Sopenharmony_ci在ArkTS中,`Number.NaN`是`Number`类型的一个特殊值。它被用来表示非数值,这里的数值是指在IEEE浮点数算术标准中定义的双精度64位格式的值。 634e41f4b71Sopenharmony_ci因为在ArkTS中`Number.NaN`独特之处在于它不等于任何值,包括它本身,与`Number.NaN`进行比较的结果是令人困惑:`Number.NaN !== Number.NaN` or `Number.NaN != Number.NaN`的值都是`true`。 635e41f4b71Sopenharmony_ci因此,必须使用`Number.isNaN()`函数来测试一个值是否是`Number.NaN`。 636e41f4b71Sopenharmony_ci 637e41f4b71Sopenharmony_ci**【反例】** 638e41f4b71Sopenharmony_ci 639e41f4b71Sopenharmony_ci``` 640e41f4b71Sopenharmony_ciif (foo == Number.NaN) { 641e41f4b71Sopenharmony_ci // ... 642e41f4b71Sopenharmony_ci} 643e41f4b71Sopenharmony_ci 644e41f4b71Sopenharmony_ciif (foo != Number.NaN) { 645e41f4b71Sopenharmony_ci // ... 646e41f4b71Sopenharmony_ci} 647e41f4b71Sopenharmony_ci``` 648e41f4b71Sopenharmony_ci 649e41f4b71Sopenharmony_ci**【正例】** 650e41f4b71Sopenharmony_ci 651e41f4b71Sopenharmony_ci``` 652e41f4b71Sopenharmony_ciif (Number.isNaN(foo)) { 653e41f4b71Sopenharmony_ci // ... 654e41f4b71Sopenharmony_ci} 655e41f4b71Sopenharmony_ci 656e41f4b71Sopenharmony_ciif (!Number.isNaN(foo)) { 657e41f4b71Sopenharmony_ci // ... 658e41f4b71Sopenharmony_ci} 659e41f4b71Sopenharmony_ci``` 660e41f4b71Sopenharmony_ci 661e41f4b71Sopenharmony_ci## 数组遍历优先使用`Array`对象方法 662e41f4b71Sopenharmony_ci 663e41f4b71Sopenharmony_ci**【级别】要求** 664e41f4b71Sopenharmony_ci 665e41f4b71Sopenharmony_ci**【描述】** 666e41f4b71Sopenharmony_ci 667e41f4b71Sopenharmony_ci对于数组的遍历处理,应该优先使用Array对象方法,如:`forEach(), map(), every(), filter(), find(), findIndex(), reduce(), some()`。 668e41f4b71Sopenharmony_ci 669e41f4b71Sopenharmony_ci**【反例】** 670e41f4b71Sopenharmony_ci 671e41f4b71Sopenharmony_ci``` 672e41f4b71Sopenharmony_ciconst numbers = [1, 2, 3, 4, 5]; 673e41f4b71Sopenharmony_ci// 依赖已有数组来创建新的数组时,通过for遍历,生成一个新数组 674e41f4b71Sopenharmony_ciconst increasedByOne: number[] = []; 675e41f4b71Sopenharmony_cifor (let i = 0; i < numbers.length; i++) { 676e41f4b71Sopenharmony_ci increasedByOne.push(numbers[i] + 1); 677e41f4b71Sopenharmony_ci} 678e41f4b71Sopenharmony_ci``` 679e41f4b71Sopenharmony_ci 680e41f4b71Sopenharmony_ci**【正例】** 681e41f4b71Sopenharmony_ci 682e41f4b71Sopenharmony_ci``` 683e41f4b71Sopenharmony_ciconst numbers = [1, 2, 3, 4, 5]; 684e41f4b71Sopenharmony_ci// better: 使用map方法是更好的方式 685e41f4b71Sopenharmony_ciconst increasedByOne: number[] = numbers.map(num => num + 1); 686e41f4b71Sopenharmony_ci``` 687e41f4b71Sopenharmony_ci 688e41f4b71Sopenharmony_ci## 不要在控制性条件表达式中执行赋值操作 689e41f4b71Sopenharmony_ci 690e41f4b71Sopenharmony_ci**【级别】要求** 691e41f4b71Sopenharmony_ci 692e41f4b71Sopenharmony_ci**【描述】** 693e41f4b71Sopenharmony_ci 694e41f4b71Sopenharmony_ci控制性条件表达式常用于`if`、`while`、`for`、`?:`等条件判断中。 695e41f4b71Sopenharmony_ci在控制性条件表达式中执行赋值,常常导致意料之外的行为,且代码的可读性非常差。 696e41f4b71Sopenharmony_ci 697e41f4b71Sopenharmony_ci**【反例】** 698e41f4b71Sopenharmony_ci 699e41f4b71Sopenharmony_ci``` 700e41f4b71Sopenharmony_ci// 在控制性判断中赋值不易理解 701e41f4b71Sopenharmony_ciif (isFoo = false) { 702e41f4b71Sopenharmony_ci ... 703e41f4b71Sopenharmony_ci} 704e41f4b71Sopenharmony_ci``` 705e41f4b71Sopenharmony_ci 706e41f4b71Sopenharmony_ci**【正例】** 707e41f4b71Sopenharmony_ci 708e41f4b71Sopenharmony_ci``` 709e41f4b71Sopenharmony_ciconst isFoo = someBoolean; // 在上面赋值,if条件判断中直接使用 710e41f4b71Sopenharmony_ciif (isFoo) { 711e41f4b71Sopenharmony_ci ... 712e41f4b71Sopenharmony_ci} 713e41f4b71Sopenharmony_ci``` 714e41f4b71Sopenharmony_ci 715e41f4b71Sopenharmony_ci## 在`finally`代码块中,不要使用`return`、`break`、`continue`或抛出异常,避免`finally`块非正常结束 716e41f4b71Sopenharmony_ci 717e41f4b71Sopenharmony_ci**【级别】要求** 718e41f4b71Sopenharmony_ci 719e41f4b71Sopenharmony_ci**【描述】** 720e41f4b71Sopenharmony_ci 721e41f4b71Sopenharmony_ci在`finally`代码块中,直接使用`return`、`break`、`continue`、`throw`语句,或由于调用方法的异常未处理,会导致`finally`代码块无法正常结束。非正常结束的`finally`代码块会影响`try`或`catch`代码块中异常的抛出,也可能会影响方法的返回值。所以要保证`finally`代码块正常结束。 722e41f4b71Sopenharmony_ci 723e41f4b71Sopenharmony_ci**【反例】** 724e41f4b71Sopenharmony_ci 725e41f4b71Sopenharmony_ci``` 726e41f4b71Sopenharmony_cifunction foo() { 727e41f4b71Sopenharmony_ci try { 728e41f4b71Sopenharmony_ci ... 729e41f4b71Sopenharmony_ci return 1; 730e41f4b71Sopenharmony_ci } catch (err) { 731e41f4b71Sopenharmony_ci ... 732e41f4b71Sopenharmony_ci return 2; 733e41f4b71Sopenharmony_ci } finally { 734e41f4b71Sopenharmony_ci return 3; 735e41f4b71Sopenharmony_ci } 736e41f4b71Sopenharmony_ci} 737e41f4b71Sopenharmony_ci``` 738e41f4b71Sopenharmony_ci 739e41f4b71Sopenharmony_ci**【正例】** 740e41f4b71Sopenharmony_ci 741e41f4b71Sopenharmony_ci``` 742e41f4b71Sopenharmony_cifunction foo() { 743e41f4b71Sopenharmony_ci try { 744e41f4b71Sopenharmony_ci ... 745e41f4b71Sopenharmony_ci return 1; 746e41f4b71Sopenharmony_ci } catch (err) { 747e41f4b71Sopenharmony_ci ... 748e41f4b71Sopenharmony_ci return 2; 749e41f4b71Sopenharmony_ci } finally { 750e41f4b71Sopenharmony_ci console.log('XXX!'); 751e41f4b71Sopenharmony_ci } 752e41f4b71Sopenharmony_ci} 753e41f4b71Sopenharmony_ci``` 754e41f4b71Sopenharmony_ci 755e41f4b71Sopenharmony_ci## 避免使用`ESObject` 756e41f4b71Sopenharmony_ci 757e41f4b71Sopenharmony_ci**【级别】建议** 758e41f4b71Sopenharmony_ci 759e41f4b71Sopenharmony_ci**【描述】** 760e41f4b71Sopenharmony_ci 761e41f4b71Sopenharmony_ci`ESObject`主要用在ArkTS和TS/JS跨语言调用场景中的类型标注,在非跨语言调用场景中使用`ESObject`标注类型,会引入不必要的跨语言调用,造成额外性能开销。 762e41f4b71Sopenharmony_ci 763e41f4b71Sopenharmony_ci**【反例】** 764e41f4b71Sopenharmony_ci 765e41f4b71Sopenharmony_ci``` 766e41f4b71Sopenharmony_ci// lib.ets 767e41f4b71Sopenharmony_ciexport interface I { 768e41f4b71Sopenharmony_ci sum: number 769e41f4b71Sopenharmony_ci} 770e41f4b71Sopenharmony_ci 771e41f4b71Sopenharmony_ciexport function getObject(value: number): I { 772e41f4b71Sopenharmony_ci let obj: I = { sum: value }; 773e41f4b71Sopenharmony_ci return obj 774e41f4b71Sopenharmony_ci} 775e41f4b71Sopenharmony_ci 776e41f4b71Sopenharmony_ci// app.ets 777e41f4b71Sopenharmony_ciimport { getObject } from 'lib' 778e41f4b71Sopenharmony_cilet obj: ESObject = getObject(123); 779e41f4b71Sopenharmony_ci``` 780e41f4b71Sopenharmony_ci 781e41f4b71Sopenharmony_ci**【正例】** 782e41f4b71Sopenharmony_ci 783e41f4b71Sopenharmony_ci``` 784e41f4b71Sopenharmony_ci// lib.ets 785e41f4b71Sopenharmony_ciexport interface I { 786e41f4b71Sopenharmony_ci sum: number 787e41f4b71Sopenharmony_ci} 788e41f4b71Sopenharmony_ci 789e41f4b71Sopenharmony_ciexport function getObject(value: number): I { 790e41f4b71Sopenharmony_ci let obj: I = { sum: value }; 791e41f4b71Sopenharmony_ci return obj 792e41f4b71Sopenharmony_ci} 793e41f4b71Sopenharmony_ci 794e41f4b71Sopenharmony_ci// app.ets 795e41f4b71Sopenharmony_ciimport { getObject, I } from 'lib' 796e41f4b71Sopenharmony_cilet obj: I = getObject(123); 797e41f4b71Sopenharmony_ci``` 798e41f4b71Sopenharmony_ci 799e41f4b71Sopenharmony_ci## 使用`T[]`表示数组类型 800e41f4b71Sopenharmony_ci 801e41f4b71Sopenharmony_ci**【级别】建议** 802e41f4b71Sopenharmony_ci 803e41f4b71Sopenharmony_ci**【描述】** 804e41f4b71Sopenharmony_ci 805e41f4b71Sopenharmony_ciArkTS提供了两种数组类型的表示方式:`T[]`和`Array<T>`。为了代码的可读性,建议所有数组类型均用`T[]`来表示。 806e41f4b71Sopenharmony_ci 807e41f4b71Sopenharmony_ci**【反例】** 808e41f4b71Sopenharmony_ci 809e41f4b71Sopenharmony_ci``` 810e41f4b71Sopenharmony_cilet x: Array<number> = [1, 2, 3]; 811e41f4b71Sopenharmony_cilet y: Array<string> = ['a', 'b', 'c']; 812e41f4b71Sopenharmony_ci``` 813e41f4b71Sopenharmony_ci 814e41f4b71Sopenharmony_ci**【正例】** 815e41f4b71Sopenharmony_ci 816e41f4b71Sopenharmony_ci``` 817e41f4b71Sopenharmony_ci// 统一使用T[]语法 818e41f4b71Sopenharmony_cilet x: number[] = [1, 2, 3]; 819e41f4b71Sopenharmony_cilet y: string[] = ['a', 'b', 'c']; 820e41f4b71Sopenharmony_ci``` 821