【el-table+vue】透明表格、自动滚动表格的实现

表格原始:
在这里插入图片描述

A.设置透明

在这里插入图片描述
实现代码:

<div class="textBox">
      <el-table
        ref="table"
        :data="tableData"
        height="250"   //设置高度是固定表头,为了后面自动滚动做准备
        :cell-style="{ 
          padding: '6px', 
          'border-bottom': '2px solid #173d91' 
        }"
        :header-cell-style="{
          hieght: '26px',
          'border-bottom': '2px solid #173d91',
        }"
        header-align="center"
        style="border-color: #868686"
      >
        <el-table-column prop="threatLevel" label="告警级别" width="140"></el-table-column>
        <el-table-column prop="deviceName" label="告警设备" width="140"></el-table-column>
        <el-table-column prop="alarmTime" label="告警时间点" width="180"></el-table-column>
        <el-table-column prop="duration" label="持续时间(分)" width="140" ></el-table-column>
        <el-table-column prop="threatName" label="告警内容"></el-table-column>
      </el-table>
</div>

重点在:.textBox /deep/ .el-table(咱不用less

<style scoped>
.textBox {
  text-align: right;
}
.textBox .el-table {
  width: 90%;
  z-index: 9;
  font-size: small;
  font-weight: 500;
  position: fixed;
  bottom: 0;
  right: 5%;
  border-radius: 5px;
}
.textBox /deep/ .el-table,
.el-table__expanded-cell {
  background-color: transparent;
}
.textBox /deep/ .el-table th {
  color: #fefefe;
  background-color: rgba(49, 210, 235, 0.5);
}
.textBox /deep/ .el-table tr {
  color: #fefefe;
  background-color: transparent !important;
}
.textBox /deep/ .el-table__body tr:hover > td {
  background-color: rgba(49, 210, 235, 0.3) !important;
}
</style>

B.设置滚动

请添加图片描述

mounted时实现函数:infinitScroll()

    infinitScroll() {
      // 拿到表格挂载后的真实DOM
      const table = this.$refs.table;
      // 拿到表格中承载数据的div元素
      const divData = table.bodyWrapper;
      divData.onmouseover = function () {
        clearInterval(t);
      }; //鼠标移入,停止滚动
      divData.onmouseout = function () {
        start();
      }; //鼠标移出,继续滚动

      // 拿到元素后,对元素进行定时增加距离顶部距离,实现滚动效果(此配置为每100毫秒移动1像素)
      let t;
      function start() {
        // 数据少于表格高度停止滚动
        if (divData.clientHeight >= divData.scrollHeight) {
          return;
        }
        t = setInterval(() => {
          // 元素自增距离顶部1像素
          divData.scrollTop += 1;
          // 判断元素是否滚动到底部(可视高度+距离顶部=整个高度)
          if (
            divData.clientHeight + divData.scrollTop ==
            divData.scrollHeight
          ) {
            // 重置table距离顶部距离
            divData.scrollTop = 0;
          }
        }, 100);
      }
      start();
    },
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
el-table 是一个基于 Vue.js表格组件,用于展示数据列表。它提供了丰富的功能,如排序、筛选、分页等。而 vue-virtual-scroller 是一个用于优化大型列表性能的 Vue 组件,它利用虚拟滚动技术来减少渲染的元素数量,从而提高性能。 当使用 el-table 渲染大量数据时,可能会遇到性能问题,因为 el-table 默认会一次性渲染所有的数据行,无论是否可见。而通过结合 vue-virtual-scroller,可以实现虚拟滚动效果,只渲染可见区域的数据行,从而提高性能并减少内存占用。 要在 el-table 中使用 vue-virtual-scroller,可以按照以下步骤进行配置: 1. 安装 vue-virtual-scroller: ```shell npm install vue-virtual-scroller ``` 2. 引入并注册 vue-virtual-scroller 组件: ```javascript import Vue from 'vue'; import { RecycleScroller } from 'vue-virtual-scroller'; Vue.component('recycle-scroller', RecycleScroller); ``` 3. 在 el-table 标签中使用 vue-virtual-scroller 组件: ```html <el-table :data="tableData" v-loading="loading"> <template slot="default" slot-scope="scope"> <recycle-scroller :items="tableData" :item-size="40" :buffer="10"> <el-table-column prop="column1" label="Column 1"> </el-table-column> <el-table-column prop="column2" label="Column 2"> </el-table-column> <!-- 其他列 --> </recycle-scroller> </template> </el-table> ``` 这样,通过 vue-virtual-scroller 来优化 el-table 渲染大量数据时的性能。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值