Vue3 + Element Plus 中修改表格当前选中行的颜色

在 Element Plus 中修改表格当前选中行的颜色,可以通过以下步骤实现:

1. 启用当前行高亮

el-table 组件上添加 highlight-current-row 属性以启用当前行高亮:

html

复制

下载

运行

复制代码
<el-table highlight-current-row>
  <!-- 表格内容 -->
</el-table>

2. 自定义选中行样式

在 CSS 中覆盖默认的高亮样式(支持全局或局部作用域):

css

复制

下载

复制代码
/* 修改选中行背景色 */
.el-table__body tr.current-row>td {
  background-color: #f3d8e5 !important; /* 自定义颜色 */
}

/* 可选:修改悬停颜色 */
.el-table__body tr.hover-row>td {
  background-color: #e1f0ff !important;
}

3. 作用域控制(可选)

若需限定样式范围,给表格添加自定义类名:

html

复制

下载

运行

复制代码
<el-table class="custom-table" highlight-current-row>
  <!-- 表格内容 -->
</el-table>

css

复制

下载

复制代码
.custom-table .el-table__body tr.current-row>td {
  background-color: #f3d8e5 !important;
}

完整示例

vue

复制

下载

复制代码
<template>
  <el-table 
    :data="tableData" 
    highlight-current-row 
    class="custom-table"
    @current-change="handleCurrentChange"
  >
    <el-table-column prop="name" label="Name"></el-table-column>
    <el-table-column prop="age" label="Age"></el-table-column>
  </el-table>
</template>

<style scoped>
/* 深度穿透(若使用 scoped) */
:deep(.custom-table .el-table__body tr.current-row>td) {
  background-color: #f3d8e5 !important;
}
/* 悬停效果 */
:deep(.custom-table .el-table__body tr.hover-row>td) {
  background-color: #e1f0ff !important;
}
</style>

说明

  • !important 用于覆盖默认样式优先级

  • 使用 :deep() 穿透 scoped 样式限制(Vue 3)

  • 颜色值可根据需求替换为十六进制、RGB 或 CSS 变量

如果需要更复杂的效果(如渐变色、边框等),可以继续扩展相关 CSS 属性。

相关推荐
极速蜗牛38 分钟前
告别部署焦虑!PinMe:前端开发者的极简部署神器
前端·javascript
uhakadotcom1 小时前
Python Protobuf 全面教程:常用 API 串联与实战指南
前端·面试·github
by__csdn1 小时前
微前端架构:从理论到实践的全面解析
前端·javascript·vue.js·架构·typescript·vue·ecmascript
漫长的~以后2 小时前
Edge TPU LiteRT V2拆解:1GB内存设备也能流畅跑AI的底层逻辑
前端·人工智能·edge
小福气_2 小时前
自定义组件 vue3+elementPlus
前端·javascript·vue.js
piaoroumi2 小时前
UVC调试
linux·运维·前端
前端不太难2 小时前
RN 调试效率低,一点小改动就需要重新构建?解决手册(实战 / 脚本 / Demo)
前端·react native·重构
是谁眉眼2 小时前
vue环境变量
前端·javascript·vue.js
3秒一个大2 小时前
JSX 基本语法与 React 组件化思想
前端·react.js
鹏北海-RemHusband2 小时前
Vue 组件解耦实践:用回调函数模式替代枚举类型传递
前端·javascript·vue.js