当前位置: 首页 > news >正文

uniapp vue3微信小程序如何获取dom元素

在网上很多人说可以通过下面两种形式获取到指定dom元素

// 定义ref
<div ref="box"></div>//1通过this.$refs获取dom元素
this.$refs.box//2通过ref(null)获取dom元素
let box = ref(null)

第一种方式在vue2中是可以获取到的,但是在vue3 setup中是没有this的(需要通过getCurrentInstance方法获取当前组件实例),所以这种方式排除

第二种方式在阅览器端是可以获取到的,但是在小程序端是获取不到的(这种方式可以获取到当前组件中的子组件实例),所以这种方式也排除

下面分两种情况来介绍如何在uniapp vue3微信小程序端获取dom元素

一、当前组件非子组件

<div id="box"></div>
//根据id获取
uni.createSelectorQuery().select('#box').node().exec(res => {//res[0].node未获取到的指定的dom元素对象console.log("res",res[0].node)
})

上面这种方式,只适合在非子组件的情况下使用,如果当前组件时作为子组件,需要通过下面的方式

二、当前为子组件

<div id="box"></div>
//根据id获取
const instance = getCurrentInstance();//获取当前组件实例
uni.createSelectorQuery().in(instance).select('#box').node().exec(res => {//res[0].node未获取到的指定的dom元素对象console.log("res",res[0].node)
})

注意:这种情况下需要传入当前组件的是你instance才能获取到指定dom元素

为啥子组件要多加一个instance才能获取到dom元素?

因为在 Vue 3 中,子组件实例不再直接暴露给全局或者父组件,而是需要通过 getCurrentInstance() 方法获取。这是为了更好地管理组件实例,确保组件在不同环境中的正确渲染和状态管理。通过 uni.createSelectorQuery().in(instance) 方法可以指定查询的范围,这里的 instance 需要是一个 DOM 节点或者一个包含 DOM 节点的组件实例。

http://www.lryc.cn/news/397180.html

相关文章:

  • Mongodb索引使用限制
  • 阿里云通义千问开源两款语音基座模型分别是SenseVoice和CosyVoice
  • 第11章 规划过程组(二)(11.10制订进度计划)
  • 如何在Spring Boot中集成Hibernate
  • Grind 75 | 3. merge two sorted lists
  • MyBatis(35)如何在 MyBatis 中实现软删除
  • C# 预处理器指令
  • Perl编译器架构:前端与后端的精细分工
  • 14-63 剑和诗人37 - 分布式系统中的数据访问设计
  • 大数据基础:Hadoop之MapReduce重点架构原理
  • 人工智能算法工程师(中级)课程3-sklearn机器学习之数据处理与代码详解
  • 华为机考真题 -- 螺旋数字矩阵
  • 防御笔记第四天(持续更新)
  • HUAWEI VRRP 实验
  • 领取serv00免费虚拟主机
  • 云开发技术的壁纸小程序源码,无需服务期无需域名
  • 基于Python的哔哩哔哩数据分析系统设计实现过程,技术使用flask、MySQL、echarts,前端使用Layui
  • 顺序结构 ( 四 ) —— 标准数据类型 【互三互三】
  • 科普文:jvm笔记
  • springboot对象参数赋值变化
  • 树形结构的一种便捷实现方案
  • 探索AI数字人的开源解决方案
  • 科普文:深入理解负载均衡(四层负载均衡、七层负载均衡)
  • 华为模拟器ensp中USG6000V防火墙web界面使用
  • 使用Python绘制气泡图
  • 政安晨:【Keras机器学习示例演绎】(五十四)—— 使用神经决策森林进行分类
  • 洞察消费者心理:Transformer模型在消费者行为分析的创新应用
  • 如何安全使用代理ip
  • 机器学习——LR、‌GBDT、‌SVM、‌CNN、‌DNN、‌RNN、‌Word2Vec等模型的原理和应用
  • 揭秘SQL Server数据库选项:性能与行为的调控者