Vue3如何动态设置ref
更新时间:2024年12月26日 08:56:52 作者:-小龙人
文章介绍了在某些场景下,需要根据动态数据来设置ref,例如在表格中的输入框需要聚焦时,需要为每个输入框设置一个ref,通过点击编辑按钮,可以自动聚焦到相应的输入框中
Vue3动态设置ref
介绍
在一些场景,ref设置是未知的需要根据动态数据来决定,如表格中的input框需要我们主动聚焦,就需要给每一个input设置一个ref,进而进行聚焦操作。
Demo
点击下面截图中的编辑按钮,自动聚焦到相应的输入框中。

<template>
<!-- 动态ref -->
<div class="test_ref">
<div v-for="item in 9" :key="item">
<span>{{ item }}</span>
<!-- 动态设置ref -->
<el-input
v-model="inputVal"
placeholder="Please input"
:ref="(el:refItem) => handleSetInputMap(el, item)"
/>
<el-button type="primary" :icon="Edit" @click="handleEdit(item)" />
</div>
</div>
</template><script lang="ts" setup>
import { ref } from "vue";
import { Edit } from "@element-plus/icons-vue";
import { ComponentPublicInstance } from "vue";
type refItem = Element | ComponentPublicInstance | null;
const inputVal = ref();
const inputRefMap = ref({});
/** 编辑 */
const handleEdit = (item: number) => {
// 若输入框此时还没有渲染出来,如先隐藏再触发显示 需要使用nextTick进行聚焦
inputRefMap.value[`Input_Ref_${item}`].input.focus();
};
/** 动态设置Input Ref */
const handleSetInputMap = (el: refItem, item: number) => {
if (el) {
inputRefMap.value[`Input_Ref_${item}`] = el;
}
};
</script><style lang="scss" scoped>
.test_ref {
padding: 50px;
> div {
width: 300px;
margin: 0 auto;
display: flex;
justify-content: center;
align-items: center;
gap: 20px;
margin-bottom: 10px;
}
}
</style>效果

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
前端vue面试总问watch和computed区别及建议总结
在现代前端的面试中,vue和react是面试过程中基本必问的技术栈,其中Vue响应式话题,watch和computed是面试官非常喜欢聊的主题,虽然watch和computed它们都用于监听数据的变化,但它们在实现原理、使用场景和行为上有着显著的区别,本文将深入探讨,并提供一些面试过程中的建议2023-10-10
Vue Baidu Map之自定义点图标bm-marker的示例
这篇文章主要介绍了Vue Baidu Map之自定义点图标bm-marker,文中给大家介绍了vue-baidu-api地图标记点(自定义标记图标),设置标记点的优先级问题,结合实例代码给大家介绍的非常详细,需要的朋友可以参考下2023-08-08
vue+jquery+lodash实现滑动时顶部悬浮固定效果
这篇文章主要为大家详细介绍了vue+jquery+lodash实现滑动时顶部悬浮固定效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2018-04-04


最新评论