如何解决ts无法识别vue中的$refs

ue中$refs可能会返回一个vue对象或者是Element对象,但是typescript并不知道这是个什么玩意儿,怎么解决这个问题呢?

解决办法是我们手动指定其类型,例如有一个ScrollView.vue组件,我在父组件中引用它。

<template>
  <scroll-view ref="scrollView"></scroll-view>
</template>

如下方式引用即可。

import ScrollView from './path/ScrollView.vue'

(this.$refs.scrollView as ScrollView).someMethod()

如果它不是一个Vue对象,而是一个Element对象的引用的话,可以这样来引用

(this.$refs.drag as HTMLElement).clientWidth

上面是一个办法,还有另一个解决的办法。就是在当前类中声明$refs所有引用。还是以上面例子中的对象为例。

export default class SomeClass extends Vue {
  public $refs!: {
    scrollView: ScrollView
  }
}

按照这个套路,把当前$refs所有可能引用到的都声明一下,再引用,ts就能正确识别了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值