初学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>
相关推荐
Aotman_7 小时前
JavaScript MutationObserver用法( 监听DOM变化 )
开发语言·前端·javascript·vue.js·前端框架·es6
酷柚易汛7 小时前
酷柚易汛ERP 2025-12-26系统升级日志
java·前端·数据库·php
Onlyᝰ7 小时前
前端调用接口进行上传文件
前端
90后的晨仔7 小时前
2025,我的“AI搭子”:那个我以为用不上的AI,成了我每天都离不开的搭档!!
前端
hashiqimiya7 小时前
JavaScript的object的使用和监控打印日志
前端·javascript·vue.js
颜酱7 小时前
从0到1实现通用微任务调度器:理解前端异步调度核心
前端
梦6508 小时前
Vue 组件 vs React 组件深度对比
javascript·vue.js·react.js
2501_946230988 小时前
Cordova&OpenHarmony提醒管理系统实现
android·javascript
C_心欲无痕8 小时前
vue3 - useId生成唯一标识符
前端·javascript·vue.js·vue3
KoalaShane8 小时前
El-slider 增加鼠标滚动滑块事件
开发语言·前端·javascript