溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

vue3中怎么通過ref獲取元素節(jié)點(diǎn)

發(fā)布時(shí)間:2022-07-28 14:52:29 來源:億速云 閱讀:442 作者:iii 欄目:開發(fā)技術(shù)

本篇內(nèi)容介紹了“vue3中怎么通過ref獲取元素節(jié)點(diǎn)”的有關(guān)知識(shí),在實(shí)際案例的操作過程中,不少人都會(huì)遇到這樣的困境,接下來就讓小編帶領(lǐng)大家學(xué)習(xí)一下如何處理這些情況吧!希望大家仔細(xì)閱讀,能夠?qū)W有所成!

通過ref獲取元素節(jié)點(diǎn)

ref 在vue2中可以說簡化js原生的document.getElementById("#id")操作 。當(dāng)然在vue3中也一樣

首先,給你想獲取到的元素一個(gè)ref 屬性

vue3中怎么通過ref獲取元素節(jié)點(diǎn)

然后,再將這個(gè)ref對(duì)象創(chuàng)建出來,就可以訪問到他的值 

但是。這樣在setup 里邊可以訪問,但是直接打印出來的值為null........

vue3中怎么通過ref獲取元素節(jié)點(diǎn)

由于 setup 函數(shù)的執(zhí)行時(shí)間要先于 html 標(biāo)簽的渲染,所以我們不能直接在 setup 函數(shù)中初始化 box 標(biāo)簽。

在生命周期函數(shù)中 setup 函數(shù)在 beforeCreate  和    Created 之間執(zhí)行

如果存在有初始化或類似的操作,需要借用 生命周期函數(shù)中的onMounted

vue3中怎么通過ref獲取元素節(jié)點(diǎn)

這樣就可以訪問到了

vue3中怎么通過ref獲取元素節(jié)點(diǎn)

獲取ref元素的幾種方式小結(jié)

1. 原生js獲取dom元素

document.querySelector(選擇器)
document.getElementById(id選擇器)
document.getElementsByClassName(class選擇器)

2. ref獲取單個(gè)dom元素

<template>
   <div ref='divDom'></div> 
</template>
<script setup>
import { ref} from 'vue'
const divDom = ref(null);
onMounted(()=>{
    console.log('獲取dom元素',divDom)
})

3. ref獲取v-for循環(huán)中的dom元素

<template>
   <div ref='getDivDom' v-for="item in list" :data-id="item.id"></div> 
</template>
<script setup>
import { ref} from 'vue'
const divDomList = ref(new Map());

const getDivDom = el=>{
    if(el){
        divDomList.set(el.dataset['id'],el) 
    }
}
// const el =divDomList.get(id) // 根據(jù)list數(shù)據(jù)中的id值 獲取對(duì)應(yīng)的dom元素

4. 在swiper中獲取swiper的dom元素

<template>
   <swiper @swiper='getSwiper'></swiper > 
</template>
<script setup>
import swiper from 'swiper'
import { ref} from 'vue'
const swiperDom= ref(null);

const getSwiper= el=>{
    swiperDom.value = el;
}

“vue3中怎么通過ref獲取元素節(jié)點(diǎn)”的內(nèi)容就介紹到這里了,感謝大家的閱讀。如果想了解更多行業(yè)相關(guān)的知識(shí)可以關(guān)注億速云網(wǎng)站,小編將為大家輸出更多高質(zhì)量的實(shí)用文章!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI