解决element-plus table组件 fixed=“right“(left)浮动后横向滚动文字穿透的问题

BUG

版本:element-plus 2.6.1

浏览器:360极速浏览器22.1 (Chromium内核)

组件:el-table组件

问题:在头部/尾部浮动加上斑马条纹后,横向滚动存在文字穿透的问题。具体如图:

白色背景行的文字,在滚动时,发生了穿透

解析

目前神奇的是,在灰色背景条纹行,文字没有穿透

查看生成结构,偶数行是这个样式控制的

看看el-table__row--striped的作用:

也就是说el-table__row--striped给下级所有的table_cell补了个底色。

而默认是什么颜色呢,看看没有el-table__row--striped作用的:

是继承上级tr的透明背景色,难怪叠加起来文字会重叠,背景透明不重叠才怪

解决

找到问题后,解决方案也很简单。在scss里给非strip的行补一个样式就好:

css 复制代码
<style lang="scss">
.cc-list-view {
  .el-table__header {
    background-color: var(--el-background-color-base);
  }

  tr.el-table__row {
    /* 解决横向滚动文字穿透的问题 */
    &.el-table__row--striped {
      .el-table__cell {
        background-color: var(--el-table-row-hover-bg-color) !important;
      }
    }
    &:not(.el-table__row--striped) {
      background-color: var(--el-bg-color) !important;
    }
  }
}
</style>

再看已经正常了

相关推荐
劉三岁12 小时前
平板网页开发,px vs rem + 适配方案
vue·电脑
蓝黑202012 小时前
Vue组件通信之emit
前端·javascript·vue
吴声子夜歌13 小时前
Vue3——v-for指令
前端·javascript·vue
xingpanvip15 小时前
PHP+JS+CSS打造动态星盘计算器
javascript·css·php
爱上好庆祝16 小时前
clip-path裁剪,css的滤镜,动画时间线,css的变量和函数
前端·css·学习·html·css3
冲浪中台17 小时前
20个常用的CSS知识点
前端·css
CodeAI1 天前
TailwindCSS 核心概念与实用技巧:从传统CSS到Utility-First迁移指南
css
滴滴答答哒1 天前
Vue3 动态路由组件加载:后台字符串到前端懒加载组件的完美转换
vue
乆夨(jiuze)2 天前
记录一个css,实现下划线内容显示,支持文本多行显示
前端·css
xiaotao1312 天前
CSS中的Grid 布局
前端·css