关于不使用ts和jsdoc ,js如何实现类型提示

首先个人认为 ts 很棒,但是写起来太繁琐了,一不小心就坠入了类型体操的地狱,jsdoc也半斤八两,例如 定义函数的参数 要写 @params这么长的字段,真麻烦,那么有没有更加简单一点的来处理,我认为是可以的,

注意必须在比较完备的编辑器中才支持(webstorm中和vscode中)

我们知道在webstorm中和vscode中 是具备简单的类型提示:如图:

可以看到 a在webstorm中因为初始化了 所以被判定为number string和数组类似 如下:

  • 规则1: 那么 如果是复杂类型呢,如何让数组里面为对象的时候也提示呢 我们可以通过初始化数组的时候先填充一个对象 再让其length变成0(通过slice(5,6) slice(-1,-2) 之类的可以让数组的长度变成0) 如下:
  • 规则2 对于复杂的对象类型 我们可以这样定义
  • 规则3 那么在vue3中 例如我们想让ref指定为dom对象 该怎么办呢 dom对象具有dom的一些特殊属性 例如style,classList... 我们可以让一个不存在的dom赋值给shallowref(实测 ref不会有类型提示) 如下:
  • 规则4 针对于函数形参或者promise.then的形参 可能稍微麻烦一点点 需要额外定义一个函数来确定形参的类型,其中if(1){}这个主要是为了保证函数在不传的情况下就是undefined,如下是promise的:

如下是函数的:

如下是函数返回值的 都能够正常提示:

如果还有 请欢迎补充哦~

相关推荐
ohyeah1 天前
JavaScript 面向对象的本质:从对象模板到组合继承的完整演进
前端·javascript
国服第二切图仔1 天前
Electron for鸿蒙PC项目实战之天气预报应用
javascript·electron·harmonyos·鸿蒙pc
Danny_FD1 天前
使用docx库实现文档导出
前端·javascript
国服第二切图仔1 天前
Electron for鸿蒙PC项目之侧边栏组件示例
javascript·electron·harmonyos·鸿蒙pc
祈澈菇凉1 天前
Next.js 零基础开发博客后台管理系统教程(一):环境搭建与项目初始化
开发语言·javascript·ecmascript
网络点点滴1 天前
Vue3路由的props
前端·javascript·vue.js
之恒君1 天前
PromiseResolveThenableJobTask 的在Promise中的使用
javascript·promise
骨子里的偏爱1 天前
uniapp实现数据存储到本地文件,除非卸载app,否则数据一直存在
javascript·chrome·uni-app
Heo1 天前
先把 Rollup 搞明白,再去学 Vite!
前端·javascript·面试
苏打水com1 天前
HTML/CSS 核心考点详解(字节跳动 ToB 中台场景)
java·前端·javascript