关于不使用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的:

如下是函数的:

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

如果还有 请欢迎补充哦~

相关推荐
海晨忆21 分钟前
【Vue】v-if和v-show的区别
前端·javascript·vue.js·v-show·v-if
JiangJiang1 小时前
🚀 Vue人看React useRef:它不只是替代 ref
javascript·react.js·面试
1024小神1 小时前
在GitHub action中使用添加项目中配置文件的值为环境变量
前端·javascript
龙骑utr1 小时前
qiankun微应用动态设置静态资源访问路径
javascript
Jasmin Tin Wei1 小时前
css易混淆的知识点
开发语言·javascript·ecmascript
wsz77771 小时前
js封装系列(一)
javascript
卫崽1 小时前
JavaScript 中的 ?? 与 || 运算符详解
javascript·面试
1024小神1 小时前
GitHub action中的 jq 是什么? 常用方法有哪些
前端·javascript
逆袭的小黄鸭1 小时前
JavaScript 开发必备规范:命名、语法与代码结构指南
前端·javascript·面试
不简说1 小时前
sv-print可视化打印组件不完全指南⑤
前端·javascript·前端框架