提高前端代码质量要从优雅的注释抓起之TSDoc

一、注释的必要性

此处省略八百字。

二、AirPower使用注释的示例

类的注释

示例

ts 复制代码
/**
 * # 用户实体
 */
export class UserEntity{
    
}

效果

属性的注释

示例

ts 复制代码
export class UserEntity{
  /**
   * # 密码
   */
  password!: string
}

效果

方法的注释

示例

ts 复制代码
  /**
   * # 😜 睡会再起来干活
   * ---
   * ### 🔞 不要忘了`await`,否则没睡醒就起来干活了 :)
   * @param milliSeconds 毫秒数
   */
  static async sleep(milliSeconds: number): Promise<void> {
    return new Promise((success) => {
      setTimeout(() => {
        success()
      }, milliSeconds)
    })
  }

效果

装饰器的注释

示例

ts 复制代码
/**
 * # 为属性标记可读名称
 * @param fieldName 属性的可读名称
 */
export function FieldName(fieldName: string): Function {
    
}

效果

装饰器参数的注释

示例

ts 复制代码
export interface IFormFieldConfig extends IFieldConfig {
  /**
   * # 是否必填(字符串类型)
   * ---
   * 💡 支持传入 ```boolean``` 和 ```string```
   * - 如传入 ```有效字符串``` 则认为需要校验, 内容即是校验失败的报错信息
   * - 如传入 ```true``` 则认为需要校验且自动生成校验失败的报错信息
   */
  requiredString?: boolean | string
}

效果

Hooks结构属性的注释

示例

ts 复制代码
export interface IUseEditorResult {
  /**
   * # 表单的验证规则
   * ---
   * 💡 你可以绑定到 ```el-form``` 的 ```:rules``` 上
   */
  rules: IValidateRule,

  /**
   * # 表单提交的方法
   * ---
   * 💡 你可以使用 ```beforeSubmit``` 方法来拦截请求的数据
   */
  onSubmit: () => void,
}

效果

Vue组件Props参数注释

示例

html 复制代码
<template>
</template>

<script lang="ts" setup="props">
import { ref } from 'vue'

const props = defineProps({
  /**
   * # 分组标题
   */
  title: {
    type: String,
    required: true,
  },

  /**
   * # 分组列数
   * ---
   * ### 💡 配置范围 ```1~3```, 默认为 ```1```
   */
  column: {
    type: Number,
    default: 1,
  },
}
</script>

效果

三、注释的原则

  • 除非必要,否则不要注释

大概是说,如果已经是约定俗成的、大部分人的共识、一些行业标准等,或者注释本身属于废话,则属于不必要的注释,不需要写注释,也尽可能不要写注释。比如:

html 复制代码
<!-- 下面是个div -->
<div></div>
js 复制代码
// 声明了一个变量
let money = 100

// 调用alert弹出提示
alert(money)
  • 如果必要,注释必须详细

如果需要写注释,那一定是详细的。

自定义的方法,需要将方法大概的功能、需要的参数和类型、方法的返回值、可能抛出的异常(如有)、参考的文档(如有)、弃用的原因(如将弃用)等信息描述完整
条件的说明,需要将条件分支进行说明。
剩下的欢迎评论区补充。

以上是我们在开发过程中的一些注释规范和心得分享,如果你有一些心得,欢迎在评论区分享。

四、参考项目

可以参考我们的前端开源项目的注释示例: github.com/HammCn/AirP...

如果你是 Java 仔,也可以参考我们关于 JavaDoc 的一些注释示例:github.com/HammCn/AirP...

就酱,又水了一桶。

相关推荐
华玥作者16 分钟前
[特殊字符] VitePress 对接 Algolia AI 问答(DocSearch + AI Search)完整实战(下)
前端·人工智能·ai
Mr Xu_37 分钟前
告别冗长 switch-case:Vue 项目中基于映射表的优雅路由数据匹配方案
前端·javascript·vue.js
前端摸鱼匠43 分钟前
Vue 3 的toRefs保持响应性:讲解toRefs在解构响应式对象时的作用
前端·javascript·vue.js·前端框架·ecmascript
lang201509281 小时前
JSR-340 :高性能Web开发新标准
java·前端·servlet
好家伙VCC2 小时前
### WebRTC技术:实时通信的革新与实现####webRTC(Web Real-TimeComm
java·前端·python·webrtc
未来之窗软件服务2 小时前
未来之窗昭和仙君(六十五)Vue与跨地区多部门开发—东方仙盟练气
前端·javascript·vue.js·仙盟创梦ide·东方仙盟·昭和仙君
嘿起屁儿整3 小时前
面试点(网络层面)
前端·网络
VT.馒头3 小时前
【力扣】2721. 并行执行异步函数
前端·javascript·算法·leetcode·typescript
phltxy4 小时前
Vue 核心特性实战指南:指令、样式绑定、计算属性与侦听器
前端·javascript·vue.js
HellowAmy4 小时前
我的C++规范 - 线程池
开发语言·c++·代码规范