vue-table那些走过的坑---持续更新

1.解决动态添加表格列顺序错乱

// 等待dom更新将表格进行重新编排 
this.$nextTick(() => {
          this.$refs.table.doLayout()
          
  })

2.动态添加表格列 fixed布局错乱

// 1.el-table身上加上loading属性
  <el-table
            ref="table"
            v-loading="loading"
            :element-loading-text="$t('sys.loading2')"
            element-loading-spinner="el-icon-loading"
            :data="tableData"
            border
            stripe
            :header-cell-style="{ background: '#F5F7FA' }"
            align="center"
            style="width: 98%; margin: 0 auto"
            height="100%"
    >
// 2.适当时机开启loading搭配dolayout将布局重新编排,如若不使用loading遮罩效果会出现闪屏的bug
//  防止闪屏被用户看到 我们可以稍微设置延时器进行延迟loading
    this.$nextTick(() => {
          this.$refs.table.doLayout()
          setTimeout(() => {
            this.tableDivLoading = false
          }, 15)
        })

// 3.修改loading 遮罩层样式 
//   我这里使用的scss  less请使用/deep/
  
::v-deep .tableDiv  .el-loading-mask{
  height: auto;
  width: auto;
  top: 0;
  left: 0;
  background-color: #fff;
  }

3.fixed状态下滚动条无法滚动


// 解决fixed下滚动条不能点击
::v-deep .el-table--scrollable-x .el-table__body-wrapper {
    z-index: 1;
  }

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
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 渲染大量数据时的性能。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值