欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue3中獲取ref元素的幾種方式總結(jié)

 更新時間:2022年12月02日 14:23:21   作者:YaaLee_  
這篇文章主要介紹了vue3中獲取ref元素的幾種方式總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

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元素了

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

最新評論