React
使用函数组件
始终使用 TSX 函数组件。 不要使用带有const的默认import,因为它更难阅读,并且更难通过代码补全功能导入。
属性
创建props类型并称为(ComponentName)Props,如果不需要导出它。
使用props解构。
避免使用 React.FC 或 React.FunctionComponent 适用于属性类型的定义
JSX元素中禁止单变量属性传播
避免在JSX元素中使用单个变量属性传播,如{...props}。 这种做法通常会导致代码不易读且难以维护,因为不清楚组件接收了哪些属性。
- 一目了然,它更清楚哪个属性代码传递下来,这使得理解和维护更容易。
- 这有助于防止组件间通过属性的紧密耦合。
- Linting工具使显式列出属性时更易于识别拼写错误或未使用的属性。
JavaScript
使用nullish 合并运算符 ??
使用可选链 ?.
TypeScript
使用 type 替代 interface
总是使用 type 而不是 interface,因为它们几乎总是重叠,而 type 更灵活。
使用字符串字面量代替枚举
字符串字面量是TypeScript中处理枚举值的首选方式。 它们可以更轻松地使用Pick和Omit扩展,并提供更好的开发者体验,特别是在代码补全时。 您可以查看这里了解为什么TypeScript建议避免使用枚举。GraphQL和内部库
应使用GraphQL codegen生成的枚举。 在使用内部库时, 使用枚举更好,这样内部库不必暴露不属于内部API的字符串文字类型。 示例:样式
使用StyledComponents
使用styled-components对组件进行样式化。主题
大多数组件样式首选利用主题。测量单位
避免在样式化组件中直接使用px或rem值。 所需的值通常已在主题中定义,因此建议为此目的使用主题。
颜色
避免引入新颜色;而是使用来自主题的现有调色板。 如果遇到调色板不匹配的情况,请留下评论以便团队纠正。强制不允许类型导入
避免类型导入。 为强制实施此标准,ESLint规则检查并报告所有类型导入。 这有助于在TypeScript代码中保持一致性和可读性。为什么不允许类型导入
- 一致性:通过避免类型导入并为类型和值导入使用单一方法,代码库在其模块导入风格上保持一致性。
- 可读性:无类型导入提高代码可读性,使得在导入值或类型时更显而易见。 这减少了歧义,并使理解导入符号的用途更容易。
- 可维护性:它增强了代码库的可维护性,因为开发人员可以在审查或修改代码时识别和定位仅类型导入。
ESLint规则
ESLint规则,@typescript-eslint/consistent-type-imports,强制执行不允许类型导入标准。 该规则会生成错误或警告以提示任何类型导入的违规。
请注意,此规则专门针对在罕见的边缘情况中发生的非预期类型导入。 TypeScript 本身也不鼓励这种做法,如TypeScript 3.8 发行说明所述。 在大多数情况下,您不需要使用仅类型导入。
为确保您的代码符合此规则,请确保在开发工作流程中运行ESLint。