如何根据条件将 class 映射到元素 UI table 中的特定行单元格?

How to map class to particular row cell in Element UI table based on condition?

<el-table :data="confirmedAppointments" highlight-current-row style="width: 100%">
                  <el-table-column type="index" width="50">
                  </el-table-column>
                  <el-table-column prop='token' label="Token" width="180">
                  </el-table-column>
                  <el-table-column prop='date'  label="Appoint. date" width="180">
                  </el-table-column>
                  <el-table-column prop='ROV' label="ROV" width="180">
                  </el-table-column>
                  <el-table-column prop='speciality' label="Speciality" width="180">
                  </el-table-column>
                  <el-table-column prop='time' label="Appoint. time" width="180">
                  </el-table-column>
                  <el-table-column prop='status' label="Status" class="red" v-bind:class="{ 'green': status == 'Accepted' }">
                  </el-table-column>

              </el-table>

我正在使用与动态数据映射的元素 UI table 组件。在最后一列,我的状态显示批准或拒绝文本。

那么如何根据单元格值将特定 class 设置为特定单元格。默认情况下,class 应为红色,但当状态值为 Approved 时,class 应为绿色。

我对元素 ui 不太熟悉,但我通过将 row-class-name 添加到 el-table

解决了同样的问题

tableRowClassName({ row }) {

    if (row.status === 'Appproved') {
        return 'success-row'
      } else if (row.status === 'Rejected') {
        return 'warning-row'
      }
      return ''
    },
  .el-table .warning-row td:last-child {  (or just .el-table td:last-child (as default color))

    background: red;
  }

  .el-table .success-row td:last-child {

    background: green;
  }
< el-table :row-class-name="tableRowClassName">

查看 cell-class-name table 属性而不是行-class-名称。它可以访问行和列数据以及行和列索引。 您应该能够自定义 classes,从而为每个单独的单元格设置样式。