vue3中获取ref元素的几种方式总结

 更新时间:2022年12月02日 14:23:21   作者:YaaLee_  
这篇文章主要介绍了vue3中获取ref元素的几种方式总结,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
(福利推荐:【腾讯云】服务器最新限时优惠活动,云服务器1核2G仅99元/年、2核4G仅768元/3年,立即抢购>>>:9i0i.cn/qcloud

(福利推荐:你还在原价购买阿里云服务器?现在阿里云0.8折限时抢购活动来啦!4核8G企业云服务器仅2998元/3年,立即抢购>>>:9i0i.cn/aliyun

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循环中的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) // 根据list数据中的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循环)

如何在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循环中获取dom元素

这种情况下,我们可以通过动态设置ref的形式进行设置ref,这样我们就可以获取到一个ref的数组

例子:

<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的形式,因为你会发现,这些方法都不能用了

所以要解决这个问题,我们需要借助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 Hook用法示例详解(6个常见hook)

    React Hook用法示例详解(6个常见hook)

    这篇文章主要介绍了React Hook用法详解(6个常见hook),本文通过实例代码给大家介绍了6个常见hook,需要的朋友可以参考下
    2021-04-04
  • react中如何使用局部样式

    react中如何使用局部样式

    这篇文章主要介绍了react中如何使用局部样式问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-10-10
  • React-View-UI组件库封装Loading加载中源码

    React-View-UI组件库封装Loading加载中源码

    这篇文章主要介绍了React-View-UI组件库封装Loading加载样式,主要包括组件介绍,组件源码及组件测试源码,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-06-06
  • 一文带你搞懂useCallback的使用方法

    一文带你搞懂useCallback的使用方法

    useCallback是用来帮忙缓存函数的,当依赖项没有发生变化时,返回缓存的指针,而props涉及到复杂对象类型都是通过指针来传递到,下面这篇文章主要给大家介绍了关于useCallback使用的相关资料,需要的朋友可以参考下
    2023-02-02
  • React Native日期时间选择组件的示例代码

    React Native日期时间选择组件的示例代码

    本篇文章主要介绍了React Native日期时间选择组件的示例代码,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-04-04
  • React.js前端导出Excel的方式

    React.js前端导出Excel的方式

    这篇文章主要为大家介绍了React.js前端导出Excel的方式详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2022-07-07
  • React路由中的redux和redux知识点拓展

    React路由中的redux和redux知识点拓展

    这篇文章主要介绍了React路由中的redux和redux知识点拓展,文章围绕主题展开详细的内容介绍,具有一定的参考价值,感兴趣的朋友可以参考学习一下
    2022-08-08
  • 在create-react-app中使用sass的方法示例

    在create-react-app中使用sass的方法示例

    这篇文章主要介绍了在create-react-app中使用sass的方法示例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2018-10-10
  • react 原生实现头像滚动播放的示例

    react 原生实现头像滚动播放的示例

    这篇文章主要介绍了react 原生实现头像滚动播放的示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-04-04
  • React Native基础入门之调试React Native应用的一小步

    React Native基础入门之调试React Native应用的一小步

    这篇文章主要给大家介绍了关于React Native基础入门之调试React Native应用的相关资料,文中通过图文介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2018-07-07

最新评论

?


http://www.vxiaotou.com