首页 > 其他分享 >vue3中获取ref元素的几种方式总结

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

时间:2023-01-26 09:55:48浏览次数:59  
标签:el const dom 元素 几种 获取 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;
}

5.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>

img

情况二:在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元素了。

标签:el,const,dom,元素,几种,获取,vue3,ref
From: https://www.cnblogs.com/echohye/p/17067574.html

相关文章

  • vue2升级vue3:vue3真的需要vuex或者Pinia吗?hooks全有了
    在写 《vue2升级vue3:TypeScript下vuex-module-decorators/vuex-classtovuex4.x》,建议新项目使用 Pinia,但是我的项目部分组件希望直接打包出去给地方使用。这个时候还是......
  • vue2升级vue3:getCurrentInstance—Composition api/hooks中如何获取$el
    在vue2中,我们进程看到this.$el操作。但是在vue3如何获取组件的当前dom元素呢? 可以利用 getCurrentInstancegetCurrentInstanceVue3.x中的核心方法:getCurrentIns......
  • VUE3/TS/TSX入门手册指北
    VUE3入门手册vue3入门首先查看官方文档:https://cn.vuejs.org/guide/quick-start.html如果有vue2基础,速成课程:https://www.zhoulujun.co/learning-vue3/component.html......
  • D. Fixed Prefix Permutations(字典树)
    Problem-D-Codeforces题意:给一个n行m列的关于m的排列数组,n个m的排列,设为q[n]对于q[i],找到最长的q[q[i]]排列是1,2,...,k,美丽值是k输出每一个的k思路:看样例一......
  • Vue2迁移Vue3,如何迁移?
    vue2对比Vue3有很多新特性增加,也有很多功能属于破坏性更新。列举值得关注的新特性第一个肯定是组合式API​​setup​​​以及​​setup语法糖​​模式新增的内置组件......
  • Vue3 setup 如何添加name
    Vue3中name有什么用呢?1.在递归组件的时候需要定义name2.配合keep-aliveincludeexclude可以缓存组件3.在Vue有报错或者调试的时候可以看到组件的nameVue3定义name1.自动......
  • Vue3 proxy 解决跨域
    1.首先我们先了解一下什么是跨域主要是出于浏览器的同源策略限制,它是浏览器最核心也最基本的安全功能。当一个请求url的协议、域名、端口三者之间任意一个与当前页面url不......
  • 说一说JavaScript有几种方法判断变量的类型?
    typeof、instanceof、Object.prototype.toString.call()(对象原型链判断方法)、constructor(用于引用数据类型)标准回答JavaScript有4种方法判断变量的类型......
  • Vue3.0 实现数据双向绑定的方法
    ue3.0是通过Proxy实现的数据双向绑定,Proxy是ES6中新增的一个特性,实现的过程是在目标对象之前设置了一层“拦截”,外界对该对象的访问,都必须先通过这层拦截,因此提供了一种机......
  • What are the difference between refrain and restrain?
    Restrainandrefrainhassamemeaning“stopyourselforapersondoingsomething“.However,ifyouareusing“restrain”,youarestoppingyourselforthe......