vue3 + ts + vite 学习笔记 (老 ref 与 新 ref 混用)

本文介绍了在Vue3中,当使用typescript和vite时,老版ref与新版ref混用的情况。讨论了在模板引用中如何声明和使用ref,特别是在遇到类型报错时,如何利用泛型和接口解决。同时,文章提到了Vue官方文档中的相关内容,并指出unref函数的作用,即从ref对象中提取实际值。

老 ref 与 新 ref 混用

文章:Vue 官方文档 - 模板引用
链接:https://v3.cn.vuejs.org/guide/composition-api-template-refs.html
使用组合式 API 时,需要事先声明 ref 并在 setup() 返回;
使用 TypeScript 的时候,ref 默认值为 null 同时变量类型也为 null 的话,后续的参数调用,则会出现类型报错,这时候需要使用到 泛型 + 接口;
注解:
好像虚拟 DOM 没有接口,只能通过泛型来替代;
console 输出是一个 proxy(代理模式);
虚拟 DOM 内是 HTMLElement 接口,是获取 HTMLElement 属性所需要的声明,例如:scrollTop, width;

可以参考以下代码,从 vue-vben-admin 项目中学习到的;

	// 泛型 或 Null
	declare type Nullable<T> = T | null;
	// 允许传入 null 为默认值
	const vueRef = ref<Nullable<HTMLElement>>(null)

unref
传入 ref 对象或变量;
主要目的是去除 ref 对象,返回 ref 对象内的值;

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值