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