Read this in other languages: English
当前网站 前端开发检查清单
本文不是代码规范,但也可能会限制您的代码风格
在 CR 新同学的代码中,有很多的知识和代码点需要重复解释,这里尝试列一个清单,以方便自己和他人。
- 任何时刻都要检查数据存在
- 任何时刻都要检查数据类型
- 任何时刻都要基于业务进行输入验证
- 任何时刻都需要在输入框内添加 max 最大长度等限制
- 优先使用 const,直到变量需要改变时改为 let
- 要敏感的对待 API 调用,尤其是针对低频调用变化为高频调用
- 编写函数时注意宽入严出,对接受的数据要宽容,对输出的数据要严格
- 注意差 1 错误,时刻考虑 <= 和 < 的差距
- 优先处理异常情况,以方便真正业务处理
- 条件判断和循环最多三层
- 限制所有代码为极为简单的控制流结构——不用 goto 语句、setjmp 或 longjmp 结构,不用间接或直接的递归调用
- 所有循环必须有一个固定的上限值。必须可以被某个检测工具静态证实,该循环不能达到预置的迭代上限值。如果该上限值不能被静态证实,那么可以认为违背该原则
- 必须在最小的范围内声明数据对象
- 不断进行函数拆分,直到用一句话能够表明意义(一个函数只完成一个功能)
- 不要设计面面俱到的函数,开发者只会编写两种代码,一种是有 bug 的,另外一种是将来有 bug 的
- 无论何时优先使用解构
- 不要在一个语句中同时处理同步数据和异步数据
- 函数返回值要,清楚,明了,统一,千万不要出现在一个函数中存在异步和同步两种结果
- 钩子函数中只写调用,而不写具体逻辑代码
- 不要扩大代码的影响
- 不要轻易的封装重复的业务代码,有可能是一种巧合而并非重复
- 注释要有侧重点,数据结构的注释是非常重要的,其次是不合理的业务逻辑然后才是正常函数
- 变量命名缩写必须能够的到团队认可,否则使用完整单词
- 常量命名全部大写,单词间用下划线隔开,力求语义表达完整清楚
- 函数命名使用 动词 + 名词的形式,如 发送短信 sendSms,如果是在模板或者 jsx 中,使用 handle + 名词 + 动词,如 处理短信发送,handle 也有具柄的意义
- 函数参数多于 3 个时使用对象传参数
- 避免使用布尔参数,如果有需要使用对象传递参数
- 尽量不要使用默认导出
- 通过代码上通过 for, by, from, when,then 等单词添加函数的意图,提供有用的额外信息
- 减少没有必要的数据类型默认转换与强制转换(分析为什么当前数据不是该数据类型,而并不是进行转换)
- 考虑在布尔运算的过程中,false 0 '' 是否和 null,undefined 意义相同
- 在进行判断的过程中,先判断范围大的,在进行小范围判断,如: 权限判断 -> 数据权限判断 -> 业务判断
- 在复杂布尔运算判断中添加括号,方便他人读懂
- if, else, for, while, do, switch, try, catch, finally 等语句的执行语句部分无论多少都要加括号 { }
- 轻易不要手动操作 DOM
- 添加定时器,以及事件等,记住清除,否则可能引发内存泄漏或者错误
- 处理异步时候,多考虑异常,同时 Promise 必须使用 resolve 或 reject 进入下一个状态,避免代码执行卡死
- 使用删除而不是注释代码来精简代码
- 避免大数组进行查询等运算,使用 Object、Map 或者 Set 进行优化
- 避免大量数据进行递归
- 除非有必要的性能要求,不要用奇技淫巧进行优化
- HTML 标签和属性操作,必须限定/过滤传入变量值
- 属性一个一行,方便使用
- 永远不要在渲染函数中进行数据修改
- 永远不要在渲染函数中创建随机值(Math.random() Date.now())
- 永远不要在渲染函数中发出网络请求
- 永远不要在渲染中创造新的组件,这将导致 React 反复销毁并重新创建子组件树
- 轻易不要复制代码,如果必需的话,请手敲一遍,确保需要执行的每一行代码都是可用的
- 对引入的开源工具都浅浅的封装一层,保证变化时候改动较小
- 结构的设计要尽量考虑向前兼容和以后的版本升级,并为某些未来可能的应用保留余地
- 解决 bug 不能只考虑 bug 本身,要分析产生的原因
- 不要在提示用户的信息的中添加语气助词以及网络用语,使用陈述句
- 不要在注释中包含侮辱性词汇
- 少引用不需要的代码,开源项目是否能够只引入一部分
- 建议不要在 package.json 依赖项中使用 ^ ~ 等,最好直接使用当前的版本号,以避免依赖项升级导致项目问题
- 尽量不使用行内样式,即使使用 props 传递,在一定范围内也要传递 class 类
- 注重语意,操作数组不需要返回值时使用 forEach,而不是 map
- 多使用可以终止的循环,如 some,every,find 等(空数组使用 some 时返回 false,every 返回 true)
- 程序要懒惰,不到最后一刻绝对不去获取或者处理数据
- 不要使用 setTimeout 解决异步问题,这将会成为一个不易重现(更加复杂)的 bug
- 在符合逻辑的情况下,尽量大的提升系统的容错,增强健壮性
- 注重事物生命周期,严格遵循初始化时候创建,结束前清理
- 使用更新的语言特性提升程序健壮性
- 单文件添加行数限制(需要由团队自行定制)
- 业务功能不要依赖语言特性
- 解析清单意义,解释为什么以及怎样做
- 借助工具搭建官网
- 完成英文翻译
- 推广,有生之年系列