【小tips】vue+iview,动态计算table高度,保证页面无竖向滚动条

本文介绍了如何在Vue+IView项目中动态计算table高度,确保页面无竖向滚动条。通过固定header、面包屑和页码器高度,结合动态获取工具栏和搜索区域高度,利用`this.$nextTick`确保DOM渲染完成后再计算。同时,文章提到了使用防抖函数优化窗口调整时的onresize事件触发,并在组件销毁时清理onresize事件,防止内存泄漏。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、场景

这是一个常规的后台管理系统的网站界面:

(orz……怎么拉伸成这个样子……)

我个人看这种界面的时候,是非常不喜欢竖向出现滚动条的,像搜索区域、工具栏这种固定的区域我希望是不动的,只需要拖拽表格的滚动条就可以看其他数据(就像上面的截图)。

 

二、解决思路:

  1. header、面包屑、页码器 的高度是固定的;
  2. 工具栏和搜索区域是不固定的,因为具栏在一个操作权限都没有的时候是看不到的,搜索条件每个界面是不固定的。
  3. this.$refs.ref.offsetHeight可以获取到元素的高度。
  4. 当界面大小改变时,有window.onresize事件可以监听,在监听事件里重新设置表格的高度即可;

综合以上四个线索,很容易的就想到了 

table height = window.innerHeight - 搜索区域高度 - 固定高度(header+面包屑) - 工具栏高度;

其实!

没错!

就是这个思路!

但是有一些需要注意的地方:

  1. mounted节点确实可以获取到dom元素了,但是并不是最终在界面上的准确布局(位置,大小ÿ
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值