vueuse的unrefElement用法

在学习vueuse模块的unrefElement用法前,先来复习下ref属性在普通html标签和自定义组件标签上的用法。

看下面的例子:

<script setup>
import JuanButton from '@/components/button'
import { onMounted, ref } from 'vue'
const btn = ref()
const span = ref()
onMounted(() => {
  console.log(btn.value)

  console.log(span.value)
})
</script>
<template>
  <div class="m-8">
    <div>
      <span ref="span" class="mr-2 inline-block border border-amber-500">我是一个span</span>
      <JuanButton ref="btn" type="primary">Hello</JuanButton>
    </div>
  </div>
</template>

在这里插入图片描述

实验发现,ref作用在普通html元素上可以通过.value访问到dom元素;而对于自定义组件,则是获取组件对象:

在这里插入图片描述

要访问组件内部的dom元素,可以访问btn.value.$el

总结下来要通过ref来访问html标签对应的元素,有两种方式:

  1. html原生dom元素

    const span = ref()
    onMounted(() => {
      console.log(span.value)
    })
    
  2. 自定义组件对应的dom

    const btn = ref()
    onMounted(() => {
      console.log(btn.value.$el)
    })
    

vueuse模块的unrefElement方法提供了统一的操作方式:

<script setup>
...
import { unrefElement } from '@vueuse/core'
const btn = ref()
const span = ref()
onMounted(() => {
  console.log(unrefElement(btn))

  console.log(unrefElement(span))
})
</script>

在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java小卷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值