elemenui中表格自定义样式row-class-name

在日常开发中,el-table是经常用到的一个标签,有些时候需要将某些内容高亮显示,如下图:
在这里插入图片描述
官方文档示列:
可以通过指定 Table 组件的 row-class-name 属性来为 Table 中的某一行添加 class,表明该行处于某种状态。
代码:

<template>
  <el-table
    :data="tableData"
    style="width: 100%"
    :row-class-name="tableRowClassName">
    <el-table-column
      prop="date"
      label="日期"
      width="180">
    </el-table-column>
    <el-table-column
      prop="name"
      label="姓名"
      width="180">
    </el-table-column>
    <el-table-column
      prop="address"
      label="地址">
    </el-table-column>
  </el-table>
</template>

<style>
  .el-table .warning-row {
    background: oldlace;
  }

  .el-table .success-row {
    background: #f0f9eb;
  }
</style>

<script>
  export default {
    methods: {
      tableRowClassName({row, rowIndex}) {
        if (rowIndex === 1) {
          return 'warning-row';
        } else if (rowIndex === 3) {
          return 'success-row';
        }
        return '';
      }
    },
    data() {
      return {
        tableData: [{
          date: '2016-05-02',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄',
        }, {
          date: '2016-05-04',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }, {
          date: '2016-05-01',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄',
        }, {
          date: '2016-05-03',
          name: '王小虎',
          address: '上海市普陀区金沙江路 1518 弄'
        }]
      }
    }
  }
</script>

照着文档,在table标签中加入 :row-class-name=“tableRowClassName”,同时在script里写想要的css样式,发现没有任何变化。
通过查看审查元素可以发现,指定列已经赋上了class,如下图:
在这里插入图片描述
仔细对比官方文档,只有在style样式中的scoped属性存在差异,其他没有差别。
只得另起一个:

<style scoped>
	::v-deep .el-result__title p {
		color: red;
	}
</style>
<style>
	.el-table .warning-row {
		background: oldlace !important;
	}
</style>

在elementUI中,row-class-name、row-style、cell-class-name等属性要想生效必须使用全局class才能生效。因为之前的代码都是在组件中编写的,所以去除中的scoped即可该组件中的样式变为全局属性。

当然这样做有个缺陷,很容易引起因为样式重复定义导致意外错误,所以更推荐第二种解决方案。
使用深度选择器/deep/ (css代码前加上 /deep/ 即可)

/deep/ #myContent input{
  /* ... */
}

注意,当使用scss或者sass时,如果发现/deep/报错,可以使用::deep替代解决。
我这里使用的是scss

<style scoped>
	::v-deep .el-table .warning-row {
		background: oldlace !important;
	}
	::v-deep .el-result__title p {
		color: red;
	}
</style>

另外,还有一个坑:
如果你的表格设置了把stripe 属性设置为了true,即斑马纹显示,那row-class-name的效果不会完全体现,显示的就只有1.3.5…行有row-class-name的样式
也就是说,row-class-name属性与stripe互斥,不能同时存在

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
element plus 是基于 Element UI 的一个组件库,提供了丰富的组件和功能,其也包括表格组件。表格组件row-class-name 属性是用于自定义表格行的样式的。 当 row-class-name 属性不生效时,可以考虑以下几个方面进行排查: 1. 检查 row-class-name 属性的使用方式是否正确。row-class-name 是作用于表格行的属性,应当放在 el-table 的 <el-table-column> 或 <el-table-column-group> 。 2. 对于 row-class-name 属性,可以传入一个函数来动态设置样式类名。检查传入的函数逻辑是否正确,以及是否有返回样式类名的语句。 3. 检查是否存在其他样式覆盖了 row-class-name 设置的样式。可以通过浏览器的开发者工具查看表格行元素的类名,确认所设置的样式是否被其他样式所覆盖。 4. 检查是否引入了正确版本的 element plus,以及是否正确注册了表格组件。确保在使用组件之前已经正确引入了 element plus 的库文件,并在 Vue 实例注册了表格组件。 5. 检查是否存在其他全局样式样式表对表格组件的样式产生了影响。有时候,全局样式或其他样式的选择器可能会影响组件的样式,导致 row-class-name 不生效。可以尝试在表格组件的父级容器加上一个唯一的样式类名,以避免样式冲突。 如果以上排查方法仍然无法解决问题,可以考虑查阅 element plus 的官方文档或寻求官方技术支持,获取更详细的帮助。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值