根据表格数据的内容来改变 Element UI 表格中的背景颜色

要根据表格数据的内容来改变 Element UI 表格中的背景颜色,你可以使用 cell-style 属性和样式函数来实现。

首先,你需要在表格的列定义中添加 cell-style 属性,该属性接收一个函数,用于根据单元格的内容返回对应的样式对象。

假设你的表格数据如下:

data() {
  return {
    tableData: [
      { nurseName: "Wang Wei", mondayStatus: "E", thursdayStatus: "E", wednesdayStatus: "E", thuesdayStatus: "E", fridayStatus: "E", saturdayStatus: "", sundayStatus: "", id: "1" },
      { nurseName: "Shi Yu", mondayStatus: "E", thursdayStatus: "E", wednesdayStatus: "E", thuesdayStatus: "E", fridayStatus: "E", saturdayStatus: "", sundayStatus: "", id: "2" },
      { nurseName: "Zhao XiaoDong", mondayStatus: "D2", thursdayStatus: "D2", wednesdayStatus: "D2", thuesdayStatus: "V", fridayStatus: "V", saturdayStatus: "", sundayStatus: "", id: "3" },
      { nurseName: "Luo Chris", mondayStatus: "D2", thursdayStatus: "D2", wednesdayStatus: "D2", thuesdayStatus: "D2", fridayStatus: "D2", saturdayStatus: "", sundayStatus: "", id: "4" },
    ]
  }
}

然后,在表格的列定义中,你可以添加 cell-style 属性来设置单元格的背景颜色,如下所示:

<el-table :data="tableData">
  <el-table-column prop="nurseName" label="Nurse Name"></el-table-column>
  <el-table-column prop="mondayStatus" label="Monday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="thursdayStatus" label="Thursday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="wednesdayStatus" label="Wednesday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="thuesdayStatus" label="Tuesday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="fridayStatus" label="Friday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="saturdayStatus" label="Saturday" :cell-style="statusCellStyle"></el-table-column>
  <el-table-column prop="sundayStatus" label="Sunday" :cell-style="statusCellStyle"></el-table-column>
</el-table>

接下来,你需要在 Vue 实例中定义对应的样式函数,根据单元格的内容返回不同的样式对象。例如:

methods: {
  statusCellStyle({ row, column }) {
    if (row[column.property] === "E") {
      return { background: "green" };
    } else if (row[column.property] === "D2") {
      return { background: "yellow" };
    } else if (row[column.property] === "V") {
      return { background: "red" };
    } else {
      return { background: "white" };
    }
  }
}

通过以上设置,每个单元格的背景颜色将根据其内容动态变化。你可以根据实际需求修改样式函数中的逻辑和颜色设置。

效果如下图

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值