vue3中獲取ref元素的幾種方式總結
vue3獲取ref元素方式
1. 原生js獲取dom元素:
document.querySelector(選擇器) document.getElementById(id選擇器) document.getElementsByClassName(class選擇器)
2. ref獲取單個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值 獲取對應的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獲取dom(包含for循環(huán))
如何在Vue3中通過ref獲取dom元素,這里說一下我遇到的情況和使用方式
情況一:只是單純的獲取某個dom元素
這種情況比較簡單,直接在js中通過ref定義一個和html中元素上ref相同名字的變量即可
例子:
<template>
<div class="box" ref="boxRef">
box
</div>
</template>
<script lang="ts" setup>
import { onMounted, ref } from 'vue';
const boxRef = ref<HTMLElement>() // 這里定義一個和div中ref名字一樣的變量名即可
onMounted(() => {
if (boxRef.value) {
console.log(boxRef.value)
}
})
</script>
情況二:在for循環(huán)中獲取dom元素
這種情況下,我們可以通過動態(tài)設置ref的形式進行設置ref,這樣我們就可以獲取到一個ref的數(shù)組
例子:
<template>
<div class="box">
<div v-for="item in 10" :key="item" :ref="setBoxRef">
box
</div>
</div>
</template>
<script lang="ts" setup>
import { onMounted, ref } from 'vue';
const boxRefs = ref<HTMLElement[]>([])
const setBoxRef = (el: any) => {
if (el) {
boxRefs.value.push(el)
}
}
onMounted(() => {
console.log(boxRefs.value)
})
</script>
情況三:獲取ref中的ref
這種情況我們不能像Vue2的方式一樣通過refs.refs或者.children的形式,因為你會發(fā)現(xiàn),這些方法都不能用了
所以要解決這個問題,我們需要借助Vue3提供的新的方法getCurrentInstance
需要注意的是,getCurrentInstance只能在setup或者生命周期中使用才有效
具體參考官方文檔:https://v3.cn.vuejs.org/api/composition-api.html#getcurrentinstance
例子:
<template>
<div class="box" ref="boxRef">
<div ref="boxInnerRef">
<div ref="innerRef">
innerRef
</div>
</div>
</div>
</template>
<script lang="ts" setup>
import { onMounted, getCurrentInstance } from 'vue';
onMounted(() => {
const instance = getCurrentInstance()
if (instance) {
console.log(instance.refs)
}
})
</script>
我們可以看到,不管多少層的ref,Vue3都給處理成了一層的Object形式,我們就能很方便的拿到自己需要的dom元素了
以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
React Router 如何使用history跳轉的實現(xiàn)
這篇文章主要介紹了React Router 如何使用history跳轉的實現(xiàn),文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2021-04-04
React+EggJs實現(xiàn)斷點續(xù)傳的示例代碼
這篇文章主要介紹了React+EggJs實現(xiàn)斷點續(xù)傳的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
React類組件中super()和super(props)的區(qū)別詳解
這篇文章給大家詳細介紹了React類組件中super()和super(props)有什么區(qū)別,文中通過代碼示例給大家介紹的非常詳細,對大家的學習或工作有一定的幫助,需要的朋友可以參考下2024-01-01

