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循环中的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中value与defaultValue的区别及说明
这篇文章主要介绍了react中value与defaultValue的区别及说明,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-05-05React+TypeScript项目中使用CodeMirror的步骤
CodeMirror被广泛应用于许多Web应用程序和开发工具,之前做需求用到过codeMirror这个工具,觉得还不错,功能很强大,所以记录一下改工具的基础用法,对React+TypeScript项目中使用CodeMirror的步骤感兴趣的朋友跟随小编一起看看吧2023-07-07react的ui库antd中form表单使用SelectTree反显问题及解决
这篇文章主要介绍了react的ui库antd中form表单使用SelectTree反显问题及解决方案,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教2023-01-01React-router v6在Class组件和非组件代码中的正确使用
这篇文章主要介绍了React-router v6在Class组件和非组件代码中的正确使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教2024-03-03用react-redux实现react组件之间数据共享的方法
这篇文章主要介绍了用react-redux实现react组件之间数据共享的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-06-06React videojs 实现自定义组件(视频画质/清晰度切换) 的操作代码
最近使用videojs作为视频处理第三方库,用来对接m3u8视频类型,这里总结一下自定义组件遇到的问题及实现,感兴趣的朋友跟随小编一起看看吧2023-08-08
最新评论