this.$refs类型识别问题 - 最详细解决方案 -【vue+typescript】

typescript是强类型所致 - typescript不能识别出this.$refs.xx是否含有xx2方法

在这里插入图片描述


方法1 - 任何类型 - 不推荐 - 一劳永逸
let myRef: any = this.$refs.myModal;
myRef.resetFields(); //清空表单校验

方法2 - HTMLFormElement - 推荐 - 一劳永逸
//成员变量
$refs!: {
    myModal: HTMLFormElement  //写法1 - 推荐
     
    //myModal: Vue & {resetFields : Function}   写法2  - 不推荐
    
    //找到xx2所在的接口并引入到组件中 
   //myModal: Vue & WrappedFormUtils  写法3 -  不推荐

};


handleCancel(e: object) {
    this.$refs.myModal.resetFields(); //清空表单校验
}

方法3 - 断言 - 不推荐
//写法1 - as
(this.$refs.myModal as Vue & {resetFields:Function}).resetFields();

//写法2 - <>
(< Vue & {resetFields : Function}>(this.$refs.myModal)).resetFields(); 

方法4 - 自己继承一个接口模板 - 推荐 - 因为支持多继承 - 在全部Vue组件中通用

AntTemplateMethod.ts文件中
在这里插入图片描述


找接口模板
在这里插入图片描述

在这里插入图片描述


App.vue文件中
在这里插入图片描述

在这里插入图片描述

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值