TS2339: Property does not exist on type 'CombinedVueInstance<Vue, unknown, ...>'的解决方案

Vue + TypeScript的项目里,在watch里使用data里定义的数据的时候,发现类型消失了,出现了这个报错:TS2339: Property does not exist on type 'CombinedVueInstance<Vue, unknown, unknown, unknown, Readonly<{ ... }>>'

查了一些资料之后,发现是因为computed没有显式声明返回类型。官方文档是这么说的:

因为 Vue 的声明文件天生就具有循环性,TypeScript 可能在推断某个方法的类型的时候存在困难。因此,你可能需要在 rendercomputed 里的方法上标注返回值。

const Component = Vue.extend({
  computed: {
    // 需要标注
    greeting(): string {
      return this.greet() + '!'
    }
  }
})

所以只需要在computed里的属性后面指明返回类型就好了。

其实仔细想想也很正常,因为没有显式声明类型的言下之意就是交给编译器进行推导,当computed里用到this的时候,如果想要知道computed的类型,就得知道this的类型,而如果想知道this的类型,又得知道computed的类型,就变成鸡生蛋蛋生鸡的问题了,所以需要显式声明类型来打破这个循环。显式声明类型之后,computed的类型就确定了,this的类型也就随之确定了。

  • 8
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值