【el-table】修改element-ui滚动条高度,并适配fixed列表最后一行错位或遮挡滚动条样式

项目场景:

elementui全局设置了公共样式,但是之前设置的滚动条只有10px高度,太小了,用户使用选不中滚动条,希望可以修改滚动条高度

原先的滚动条


解决方法

关于修改滚动条:

在common文件中设置全局的滚动条宽高

::-webkit-scrollbar {
	width: 10px;
	height: 15px; //主要是高度
}

可以简单改变滚动条高度

在这里插入图片描述

问题一:

有数据时,原先fixed的内容会遮挡滚动条

在这里插入图片描述

这个时候将两侧fixed固定列的高度设为自动,在底部增加一个滚动条高度,不让遮挡生效

	.el-table__fixed,
	.el-table__fixed-right {
		height: auto !important;
		bottom: 15px !important; // 滚动条高度
	}

修改效果:
在这里插入图片描述


问题二:

全局修改之后,发布过了一段时间用户提出数据右侧有空白区域遮挡

原因:用户电脑为2k大屏,足够大,所以表单并没有显示滚动条,而全局设置的fixed的bottom导致页面高度不够,形成了空白区域

在这里插入图片描述

通过搜索,发现有两种方法
1、强制设置滚动效果让左侧区域也往上缩,使左右两侧都有空白区域,能给视觉上对齐,但是会导致最后一行数据左右对不上,因为问题本质是fixed列表高度不够

.el-table__body-wrapper {
    overflow-x: scroll !important;//直接设置横轴内容滚动条(无法达到效果)
  }

2、通过将fiexd列表高度变成100%,但是造成有滚动条的时候遮挡滚动条,并非想要的效果

.el-table__fixed {
  height: 100% !important; //设置高度100%
  }

但是这个给了一个思路,因为本质问题是fiexd列表高度不足,因此可以单独设置当滚动条不出现时候的样式状态,这样就不会导致滚动条出现时候的遮挡

然后在修改的过程中还发现一个问题,当有滚动条的时候,拉到最后一行,这个左右行还是有些对不上,只是没有滚动条的时候错位更加明显

在这里插入图片描述

最终方案

	// 当表格没有滚动条时
	.el-table__body-wrapper.is-scrolling-none~.el-table__fixed-right,
	.el-table__body-wrapper.is-scrolling-none~.el-table__fixed {
		height: 100% !important;
	}
	// 优化左右对不上的问题
	.el-table__fixed-body-wrapper .el-table__body {
		padding-bottom: 15px; // 滚动条高度
	}

完美解决

自己的经验分享,请各位指正

参考:
解决使用fixed最后一行被遮挡
针对没有滚动条的样式

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值