vue3 el-table 行颜色根据 字段改变

在 Vue 3 中使用 Element Plus 的 <el-table> 组件来根据某个字段改变行的颜色,可以通过自定义渲染函数或使用 row-class-name 属性来实现。以下是两种常见的方法:

方法 1:使用 row-class-name 属性

<el-table> 组件的 row-class-name 属性允许你根据行的数据动态返回一个类名,你可以在这个类名中定义颜色。

复制代码
<template>
  <el-table :data="tableData" row-class-name="rowClassName">
    <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>
 
<script setup>
import { ref } from 'vue';
 
const tableData = ref([
  { date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', type: 'A' },
  { date: '2016-05-04', name: '张小刚', address: '上海市普陀区金沙江路 1517 弄', type: 'B' },
  // 更多数据...
]);
 
const rowClassName = ({ row, rowIndex }) => {
  if (row.type === 'A') {
    return 'row-color-a';
  } else if (row.type === 'B') {
    return 'row-color-b';
  }
  return ''; // 默认返回空字符串,不应用任何特殊样式
};
</script>
 
<style>
.row-color-a {
  background-color: #f0f9eb; /* 例如,类型A的行背景色 */
}
.row-color-b {
  background-color: #ebf4fa; /* 例如,类型B的行背景色 */
}
</style>

方法 2:使用自定义渲染函数

如果你需要更复杂的行样式控制,可以使用 <el-table-column>render 函数来自定义每一行的渲染。

复制代码
<template>
  <el-table :data="tableData">
    <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-column label="操作" width="100">
      <template #default="{ row, rowIndex }">
        <div :class="getRowClass(row)">{{ row.type }}</div>
      </template>
    </el-table-column>
  </el-table>
</template>
 
<script setup>
import { ref } from 'vue';
 
const tableData = ref([
  { date: '2016-05-02', name: '王小虎', address: '上海市普陀区金沙江路 1518 弄', type: 'A' },
  { date: '2016-05-04', name: '张小刚', address: '上海市普陀区金沙江路 1517 弄', type: 'B' },
  // 更多数据...
]);
 
const getRowClass = (row) => {
  if (row.type === 'A') {
    return 'row-color-a';
  } else if (row.type === 'B') {
    return 'row-color-b';
  }
  return ''; // 默认返回空字符串,不应用任何特殊样式
};
</script>
 
<style>
.row-color-a {
  background-color: #f0f9eb; /* 例如,类型A的行背景色 */
}
.row-color-b {
  background-color: #ebf4fa; /* 例如,类型B的行背景色 */
}
</style>

这两种方法都可以根据字段。

相关推荐
华仔啊8 小时前
JavaScript 如何准确判断数据类型?5 种方法深度对比
前端·javascript
毕设十刻8 小时前
基于Vue的迅读网上书城22f4d(程序 + 源码 + 数据库 + 调试部署 + 开发环境配置),配套论文文档字数达万字以上,文末可获取,系统界面展示置于文末
前端·数据库·vue.js
程序员小寒8 小时前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
开发语言·前端·javascript·面试
爱健身的小刘同学9 小时前
Vue 3 + Leaflet 地图可视化
前端·javascript·vue.js
神秘的猪头9 小时前
Ajax 数据请求:从零开始掌握异步通信
前端·javascript
黛色正浓9 小时前
leetCode-热题100-贪心合集(JavaScript)
javascript·算法·leetcode
musashi10 小时前
用 Electron 写了一个 macOS 版本的 wallpaper(附源码、下载地址)
前端·vue.js·electron
徐徐子10 小时前
从vue3 watch开始理解Vue的响应式原理
前端·vue.js
拾荒的小海螺10 小时前
开源项目:Three.js 构建 3D 世界的工具库
javascript·3d·开源
还债大湿兄10 小时前
huggingface.co 下载有些要给权限的模型 小记录
开发语言·前端·javascript