解决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>

再看已经正常了

相关推荐
爱上好庆祝4 小时前
svg图片
前端·css·学习·html·css3
whuhewei9 小时前
JS获取CSS动画的旋转角度
前端·javascript·css
蓝黑20209 小时前
Vue组件通信之v-model
前端·javascript·vue
不会写DN12 小时前
Vue3中的computed 与 watch 的区别
javascript·面试·vue
钛态15 小时前
前端WebSocket实时通信:别再用轮询了!
前端·vue·react·web
冰暮流星15 小时前
javascript之dom访问css
开发语言·javascript·css
千码君201616 小时前
kotlin:jetpack compose 生成动态可控的动画
vue.js·elementui·kotlin
蓝黑202016 小时前
Vue组件通信之slot
前端·javascript·vue
榴莲omega16 小时前
第13天:CSS(二)| Grid 布局完全指南
前端·css·js八股
牧杉-惊蛰16 小时前
修改表格选中时的背景色与鼠标滑过时的背景色
前端·javascript·css·vue.js·elementui·html