首頁 > web前端 > Vue.js > vue3中怎麼透過ref取得元素節點

vue3中怎麼透過ref取得元素節點

PHPz
發布: 2023-05-16 12:25:06
轉載
5155 人瀏覽過

透過ref取得元素節點

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

首先,給你想取得到的元素一個ref 屬性

vue3中怎麼透過ref取得元素節點

然後,再將這個ref物件建立出來,就可以訪問到他的值 

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

vue3中怎麼透過ref取得元素節點

#由於 setup 函數的執行時間要先於 html 標籤的渲染,所以我們不能直接在 setup 函數中初始化 box 標籤。

在生命週期函數中setup 函數在beforeCreate  和    Created 之間執行

如果存在有初始化或類似的操作,需要藉用生命週期函數中的onMounted

vue3中怎麼透過ref取得元素節點

#這樣就可以存取到了

vue3中怎麼透過ref取得元素節點

取得ref元素的幾種方式小結

1. 原生js取得dom元素

document.querySelector(选择器)
document.getElementById(id选择器)
document.getElementsByClassName(class选择器)
登入後複製

2. ref取得單一dom元素

<template>
   <div ref=&#39;divDom&#39;></div> 
</template>
<script setup>
import { ref} from &#39;vue&#39;
const divDom = ref(null);
onMounted(()=>{
    console.log(&#39;获取dom元素&#39;,divDom)
})
登入後複製

3. ref取得v-for循環中的dom元素

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

const getDivDom = el=>{
    if(el){
        divDomList.set(el.dataset[&#39;id&#39;],el) 
    }
}
// const el =divDomList.get(id) // 根据list数据中的id值 获取对应的dom元素
登入後複製

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

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

const getSwiper= el=>{
    swiperDom.value = el;
}
登入後複製

以上是vue3中怎麼透過ref取得元素節點的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:yisu.com
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板