初学vue3与ts:获取组件ref实例

typescript 复制代码
/**
 * 获取组件ref
 * @param {VueComponentIns} 组件实例
 * @returns 组件ref
 */
// eslint-disable-next-line
export function useCompRef<T extends abstract new (...args: any) => any>(_: T) {
	return ref<InstanceType<T>>();
}

使用

html 复制代码
<a-com ref="aComRef"></a-com>
<script lang="ts" setup>
import ACom from '@/components/a-com.vue';
//引入
import { useCompRef } from '@/sss/useRefs';
const aComRef = useCompRef(ACom);
//调用组件里的函数,比如说这个组件是一个弹窗,那么打开弹窗
const openCom = () => {
	aComRef.value?.open();
};
</script>
相关推荐
兆子龙1 分钟前
Vite 打包优化实战:从 12.17M 到 7.95M 的瘦身之旅
javascript
nunumaymax7 分钟前
css实现元素和文字从右向左排列
前端·css
confiself18 分钟前
A2UI实时渲染展示
开发语言·javascript·css
旷世奇才李先生24 分钟前
043校园二手交易平台系统-springboot+vue
java·vue.js·spring boot
yatum_201439 分钟前
CentOS 7 集群 SSH 免密与主机名配置文档
linux·前端·网络
014-code1 小时前
Vue 生命周期完全指南
前端·javascript·vue.js
冴羽yayujs1 小时前
资深前端都在用的 9 个调试偏方
前端·javascript·调试
Amumu121381 小时前
CSS移动端
前端·css·css3
lichenyang4531 小时前
组件设计模式与通信
前端·javascript·设计模式