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

如下是函数的:

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

如果还有 请欢迎补充哦~

相关推荐
Micro麦可乐8 分钟前
前端图片裁剪上传全流程详解:从预览到上传的完整流程
前端·javascript·图片上传·图片裁切·cropper.js
Python私教3 小时前
PrimeVue菜单组件深度解析:构建高效能的Web导航系统
前端·javascript·vue.js
黑匣子~5 小时前
Vue 3 官方 Hooks 的用法与实现原理
前端·javascript·vue.js
霍志杰7 小时前
iframe加载或者切换时候,短暂的白屏频闪问题解决
前端·javascript·chrome
愛芳芳8 小时前
vue3+element-plus+pinia完整搭建好看简洁的管理后台
前端·javascript·vue.js
麻辣香蝈蝈9 小时前
【Vue3】一文学会动态路由和编程式路由的使用
开发语言·前端·javascript·vue.js
magic 24510 小时前
AJAX get请求如何提交数据呢?
前端·javascript·ajax
i1yo_kiki11 小时前
Ajax快速入门教程
前端·javascript·ajax
霖0012 小时前
同步/异步电路;同步/异步复位
开发语言·前端·javascript·嵌入式硬件·fpga开发·信号处理
三三十二12 小时前
Labview基础使用教程
服务器·前端·javascript