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

vue3动态监听div高度案例

案例场景

在这里插入图片描述
场景描述:现在左边的线条长度需要根据右边盒子的高度进行动态变化

实践代码案例

HTML部分
<div v-for="(device, index) in devices" :key="index"><!-- 动态设置 .left-bar 的高度 --><div class="left-bar" :style="{ height: `${contentHeights[index] || 30}px` }"></div><div :ref="(el) => { contentRefs[index] = el as HTMLElement }"><span>设备编号:{{ device.code }}</span><span>异常信息:{{ device.info }}</span></div>
</div>
JS部分
import { reactive, toRefs, ref, onMounted, watch, nextTick } from 'vue';interface Device {code: string;status: string;info: string;
}const state = reactive({devices:[{code: 'JS23053001',status: '异常',info: '提升激光仪通讯故障 提升激光仪通讯故障 备用(从站数据故障) 备用(从站数据故障)'},{code: 'JS23053002',status: '异常',info: '货物左超 过载保护 断绳保护 超速保护 行走超限 升降超限'},{ code: 'JS23053003', status: '正常', info: '正常' },{ code: 'JS23053003', status: '正常', info: '正常' },{code: 'JS23053003',status: '异常',info: '行走变频器通讯故障 行走变频器通讯故障 货叉1变频器通讯故障'}],
});const { devices } = toRefs(state);// 用于存储每个 content 元素的引用
const contentRefs = ref<(HTMLElement | null)[]>([]);// 存储每个设备的 .content 元素的高度
const contentHeights = ref<number[]>([]);// 更新每个设备的 content 高度
const updateContentHeight = () => {
contentHeights.value = contentRefs.value.map(contentRef => {// 获取每个 content 元素的高度return contentRef ? contentRef.clientHeight : 0;});
};// 监听设备列表变化,重新更新高度
watch(() => state.devices, () => {nextTick(() => updateContentHeight()); // 确保 DOM 渲染完成后获取高度
}, { immediate: true });
Style部分(left-bar)
.device-item .left-bar {width: 2px;            // 宽度margin-right: 0.2rem;  // 距离
}

注意:

  • 使用 nextTick 确保 DOM 渲染完成后再更新 contentHeights。这能保证获取到准确的高度信息
  • 给 .left-bar 设置一个默认高度(例如 30px)来确保它始终可见,即使计算出来的高度是 0 时。你可以调试默认高度,并逐步确保 contentHeights 数组能够正常更新
  • contentRefs 是一个数组,用来存储每个 .content 的引用。由于 v-for 渲染的组件是异步的,可能 contentRefs 没有及时更新,导致没有正确获取到每个 .content 的高度
http://www.lryc.cn/news/477154.html

相关文章:

  • 数据转换 | Matlab基于SP符号递归图(Symbolic recurrence plots)一维数据转二维图像方法
  • 分类算法——逻辑回归 详解
  • 只允许指定ip远程连接ssh
  • Rust 力扣 - 2841. 几乎唯一子数组的最大和
  • TwinCL: A Twin Graph Contrastive Learning Model for Collaborative Filtering
  • 如何区分实例化网格中的每个实例
  • 理解 WordPress | 第一篇:与内容管理系统的关系
  • Python游戏脚本之实现飞机大战(附源码)
  • 使用Spring Boot搭建简单的web服务
  • 【IF-MMIN】利用模态不变性特征进行缺失模态的鲁棒多模态情感识别
  • RGB图像,排列方式NHWC适合CPU计算,NCHW适合GPU计算
  • 布朗运动
  • WPF+MVVM案例实战(二十二)- 制作一个侧边弹窗栏(CD类)
  • 集成旺店通旗舰版售后单至MySQL数据库
  • 【Linux】从零开始使用多路转接IO --- epoll
  • 爬虫学习4
  • CTF之web题集详情随手笔记
  • TDengine 集群能力:超越 InfluxDB 的水平扩展与开源优势
  • MATCH_DIRECT_BOOT_AWARE和MATCH_DIRECT_BOOT_UNAWARE
  • LabVIEW离心泵性能优化测试系统
  • token和jwt区别
  • 新闻稿件管理:SpringBoot框架实战指南
  • AI运动小程序开发常见问题集锦二
  • nginx安装
  • 【Linux驱动开发】内核定时器的配置和使用
  • Kubernetes架构及核心组件
  • Fastflow工作流系统源码
  • 小林渗透入门:burpsuite+proxifier抓取小程序流量
  • AiPPT - 全智能 AI 一键生成 PPT
  • React 前端使用 Input 输入框的样式上传一个 Excel 文件并读取内容对象数组