el-table自定义样式,表头固定,数据过多时滚动

2024-08-22 18:20

本文主要是介绍el-table自定义样式,表头固定,数据过多时滚动,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

最终效果:(此处没体现出来滚动,数据没那么多)

1.表头固定,设置表头样式,修改表格背景色

<div class="category-table">

   <el-table

          ref="tableRef"

          class="common-table"

          height="100%"

          :row-style="{ height: rowHeight + 'px' }"

          :header-row-style="{

            background: `url(${tableHeader}) center no-repeat !important`,

            backgroundSize: `100% 100% !important`,

          }"

          style="width: 100%; height: 100%; background-color: transparent"

        >

  </el-table>

</div>

动态设置行高,在获取到数据以后,记得加一个$nextTick(),不然会报错

// 在获取到表格数据后,判断数据长度大于0后调用
this.$nextTick(() => {this.initRowHeight();
});// 设置行高initRowHeight() {let tableHeight =Math.round(this.$refs["tableRef"].$el.offsetHeight) -Math.round(this.$refs["tableRef"].$el.childNodes[1].offsetHeight);this.rowHeight = Math.floor(tableHeight / 10); // 返回小于等于最终结果的最大整数setTimeout(() => {if (this.$refs.tableRef) {this.$refs.tableRef.doLayout();}}, 1000);},

2.写在有scoped 的style标签内
/* 显示滚动条 */
.category-table ::v-deep .el-table--scrollable-x .el-table__body-wrapper {overflow-y: scroll;
}
/* 设置表格的滚动条宽度 */
.category-table >>> .el-table__body-wrapper::-webkit-scrollbar {width: 10px;height: 8px;
}
/*定义滚动条轨道 内阴影+圆角*/
.category-table >>> .el-table__body-wrapper::-webkit-scrollbar-track {border-radius: 8px;background-color: transparent;
}
/*定义滑块 内阴影+圆角*/
.category-table >>> .el-table__body-wrapper::-webkit-scrollbar-thumb {border-radius: 8px;box-shadow: inset 0 0 6px rgba(200, 209, 217, 0.3);background-color: rgba(76, 77, 77, 0.1);
}
 3.公共的scss样式文件内,没有公共样式文件的话可以放在没有scoped的style标签内,有的话要保证在main.js里引入了
/* el-table表格组件样式 */
.common-table {/* 表格加载中的背景 */.el-loading-mask {background-color: transparent;}/** 设置表格暂无数据样式 */.el-table__empty-block {background-color: transparent;color: #a8bfd5;letter-spacing: 2px;}/** 修改表头多选样式 */.el-checkbox__inner {background-color: transparent;}.el-checkbox__inner:hover {border: 1px solid #6d90ae;}.el-checkbox__input.is-checked .el-checkbox__inner {background-color: #1173be;}/* 设置表头样式 */&.el-table .el-table__header-wrapper th {color: #85b4e6;font-weight: normal;font-size: var(--font-size-base);letter-spacing: 2px;background-color: transparent !important;background: url("/images/imagine/table-header.png") center no-repeat;background-size: 100% 100%;border-bottom: 1px solid #0b4f85;box-sizing: border-box;}/** 设置表格的行背景色 */.el-table__row {background: url("/images/imagine/table-row1.png") center no-repeat;background-size: 100% 100%;}/** 去掉每一行的底边border */&.el-table td.el-table__cell {color: #aec4da;border-bottom: 1px solid #0b4f85;font-size: var(--font-size-base);letter-spacing: 2px;}/* 修改表格上侧和左侧的border */&.el-table--border,&.el-table--group,/* 修改表格右侧和底侧的border */&.el-table--border:after,&.el-table--group:after,&.el-table:before {border-color: transparent;}/* 删除表格右侧的border */&.el-table--border::after {width: 0;}/** 设置表格左侧第一列的边 */&.el-table td.el-table__cell:first-child {border-left: 1px solid #0b4f85;}/** 去掉表格的底边border */&.el-table::before {height: 0;}/** 去掉表格头部的border */&.el-table--border {border: none;}/** 表格内部每一列右侧border */&.el-table--border .el-table__cell {border-right: 1px solid #0b4f85;}/** 表格行的鼠标滑过样式 */&.el-table tbody tr:hover>td {background: url("/images/imagine/table-row2.png") center no-repeat !important;background-size: 100% 100% !important;}/* 去掉表格滚动条那一列的border */&.el-table--border th.el-table__cell.gutter:last-of-type {border-bottom-width: 0;}
}

这篇关于el-table自定义样式,表头固定,数据过多时滚动的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1097034

相关文章

Linux下利用select实现串口数据读取过程

《Linux下利用select实现串口数据读取过程》文章介绍Linux中使用select、poll或epoll实现串口数据读取,通过I/O多路复用机制在数据到达时触发读取,避免持续轮询,示例代码展示设... 目录示例代码(使用select实现)代码解释总结在 linux 系统里,我们可以借助 select、

通过React实现页面的无限滚动效果

《通过React实现页面的无限滚动效果》今天我们来聊聊无限滚动这个现代Web开发中不可或缺的技术,无论你是刷微博、逛知乎还是看脚本,无限滚动都已经渗透到我们日常的浏览体验中,那么,如何优雅地实现它呢?... 目录1. 早期的解决方案2. 交叉观察者:IntersectionObserver2.1 Inter

C#中通过Response.Headers设置自定义参数的代码示例

《C#中通过Response.Headers设置自定义参数的代码示例》:本文主要介绍C#中通过Response.Headers设置自定义响应头的方法,涵盖基础添加、安全校验、生产实践及调试技巧,强... 目录一、基础设置方法1. 直接添加自定义头2. 批量设置模式二、高级配置技巧1. 安全校验机制2. 类型

C#使用iText获取PDF的trailer数据的代码示例

《C#使用iText获取PDF的trailer数据的代码示例》开发程序debug的时候,看到了PDF有个trailer数据,挺有意思,于是考虑用代码把它读出来,那么就用到我们常用的iText框架了,所... 目录引言iText 核心概念C# 代码示例步骤 1: 确保已安装 iText步骤 2: C# 代码程

Pandas处理缺失数据的方式汇总

《Pandas处理缺失数据的方式汇总》许多教程中的数据与现实世界中的数据有很大不同,现实世界中的数据很少是干净且同质的,本文我们将讨论处理缺失数据的一些常规注意事项,了解Pandas如何表示缺失数据,... 目录缺失数据约定的权衡Pandas 中的缺失数据None 作为哨兵值NaN:缺失的数值数据Panda

C++中处理文本数据char与string的终极对比指南

《C++中处理文本数据char与string的终极对比指南》在C++编程中char和string是两种用于处理字符数据的类型,但它们在使用方式和功能上有显著的不同,:本文主要介绍C++中处理文本数... 目录1. 基本定义与本质2. 内存管理3. 操作与功能4. 性能特点5. 使用场景6. 相互转换核心区别

python库pydantic数据验证和设置管理库的用途

《python库pydantic数据验证和设置管理库的用途》pydantic是一个用于数据验证和设置管理的Python库,它主要利用Python类型注解来定义数据模型的结构和验证规则,本文给大家介绍p... 目录主要特点和用途:Field数值验证参数总结pydantic 是一个让你能够 confidentl

JAVA实现亿级千万级数据顺序导出的示例代码

《JAVA实现亿级千万级数据顺序导出的示例代码》本文主要介绍了JAVA实现亿级千万级数据顺序导出的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面... 前提:主要考虑控制内存占用空间,避免出现同时导出,导致主程序OOM问题。实现思路:A.启用线程池

SpringBoot AspectJ切面配合自定义注解实现权限校验的示例详解

《SpringBootAspectJ切面配合自定义注解实现权限校验的示例详解》本文章介绍了如何通过创建自定义的权限校验注解,配合AspectJ切面拦截注解实现权限校验,本文结合实例代码给大家介绍的非... 目录1. 创建权限校验注解2. 创建ASPectJ切面拦截注解校验权限3. 用法示例A. 参考文章本文

SpringBoot分段处理List集合多线程批量插入数据方式

《SpringBoot分段处理List集合多线程批量插入数据方式》文章介绍如何处理大数据量List批量插入数据库的优化方案:通过拆分List并分配独立线程处理,结合Spring线程池与异步方法提升效率... 目录项目场景解决方案1.实体类2.Mapper3.spring容器注入线程池bejsan对象4.创建