vue3動態(tài)綁定ref并獲取其dom實現(xiàn)方式
更新時間:2025年07月23日 14:41:30 作者:meng半顆糖
Vue3中動態(tài)綁定ref建議用對象存儲,通過索引訪問嵌套元素;或使用計算屬性獲取DOM,兩種方法可提升靈活性,適用于v-for循環(huán)場景,便于操作單/多層嵌套結(jié)構(gòu)
vue3動態(tài)綁定ref并獲取其dom
方法1:v-for
在 v-for 中建議用對象存儲 refs 而非數(shù)組
- 函數(shù)參數(shù)
el:動態(tài)綁定時會傳入當(dāng)前 DOM 元素或組件實例
<template>
<div v-for="item in items" :key="item.id">
<div :ref="(el) => setItemRef(el, item.id)"></div>
</div>
</template>
<script setup>
import { ref } from 'vue'
const items = ref([{ id: 1 }, { id: 2 }])
const itemRefs = ref({})
const setItemRef = (el, id) => {
if (el) {
itemRefs.value[id] = el // 存儲 DOM 引用
}
}
onMounted(() => {
console.log(itemRefs.value) // 輸出 {1: div, 2: div}
})
</script>
for循環(huán) 可使用單/多層 嵌套
<!-- 單層循環(huán) -->
<div v-for="(item, index) in list" :key="index">
<input :ref="(el) => (refsArray[index] = el)" />
</div>
<!-- 嵌套循環(huán) -->
<div v-for="(group, i) in groups" :key="i">
<div v-for="(item, j) in group.items" :key="j">
<input :ref="(el) => (nestedRefs[i][j] = el)" />
</div>
</div>
通過 refsArray[index] 或 nestedRefs[i][j] 即可訪問嵌套元素
方法2:使用計算屬性
const getRefName = (index) => `itemRef_${index}`
總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
學(xué)習(xí)vue.js中class與style綁定
這篇文章主要和大家一起學(xué)習(xí)vue.js中class與style綁定操作,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12
vue跳轉(zhuǎn)外部鏈接始終有l(wèi)ocalhost的問題
這篇文章主要介紹了vue跳轉(zhuǎn)外部鏈接始終有l(wèi)ocalhost的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-03-03
vue-cli創(chuàng)建vue項目的詳細(xì)步驟記錄
vue.cli是vue中的項目構(gòu)造工具,是一個npm包,需要安裝node.js和 git才能用,下面這篇文章主要給大家介紹了關(guān)于利用vue-cli創(chuàng)建vue項目的詳細(xì)步驟,需要的朋友可以參考下2022-06-06
關(guān)于Vue?CLI3中啟動cli服務(wù)參數(shù)說明
這篇文章主要介紹了關(guān)于Vue?CLI3中啟動cli服務(wù)參數(shù)說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-04-04

