解决Antd 表格固定列后列间有空白间隙的问题

1 篇文章 0 订阅
1 篇文章 0 订阅

问题描述:

antd 表格设置列fixed属性,scroll为x:true后,如果列数少,会出现列间空白间隙。

原因:

antd的表格为了实现固定列,横向滚动的效果,会多渲染出一个用于覆盖原始表格固定列的表格,该表格只渲染被固定的列,然后在横向滚动条滚动时,该表格固定不动,下面被覆盖的原始表格来回滚动,从而实现左右某些列固定,中间列可以滚动的效果。然后,在渲染时,两个表格固定列每一列的列宽度不一致,而被覆盖的列的css属性设置了visibility:hidden,一旦被覆盖的固定列宽度过大,就会出现空白间隙。

解决方案:

通过js调整两个固定列的宽度,让其一致。

代码:

1、给表格、左固定列、右固定列加了唯一的className,

 <div className={'crud-basic-table'}>
        <Table 
          rowKey={this.getRowKey}
          scroll={{ x: true }}
          rowSelection={rowSelection}
          columns = {columns}
          dataSource={dataSource}
          pagination={paginationProps}
          {...rest}
          ref={(ref) => { this.refDom = ref; }}
        />
      </div>
   if(columns && columns.length>0){
    columns.forEach(col => {
      if ('fixed' in col) {
        if(col.fixed==='true'||col.fixed==='left'){
          col.className = col.className?col.className+' antd-table-fixed-left-column':'antd-table-fixed-left-column'
        }else if(col.fixed==='right'){
          col.className = col.className?col.className+' antd-table-fixed-right-column':'antd-table-fixed-right-column'
        }
      }
    })
   }

然后在document.ejs的js脚本中,新增脚本如下:

  <script>
      //解决Antd 列空白间隙问题
      //表格固定列宽度设置为底层被覆盖的固定列宽度
      var crudTable = document.getElementsByClassName('crud-basic-table');
      for (var i = 0; i < crudTable.length; i++) {
        var ct = crudTable[i];
        //左侧固定列
        var lf = ct.getElementsByClassName('ant-table-fixed-left');
        if(lf.length>0){
          var lfColumn = lf[0].getElementsByClassName('antd-table-fixed-left-column');
          var fixedLfCol = ct.getElementsByClassName("ant-table-fixed-columns-in-body antd-table-fixed-left-column");
          for (let j = 0; j < lfColumn.length; j++) {
            lfColumn[j].style.width = fixedLfCol[j].offsetWidth+"px";
          }
        }
        //右侧固定列
        var rg = ct.getElementsByClassName('ant-table-fixed-right');
        if(rg.length>0){
          var rgColumn = rg[0].getElementsByClassName('antd-table-fixed-right-column');
          var fixedRgCol = ct.getElementsByClassName("ant-table-fixed-columns-in-body antd-table-fixed-right-column");
          for (let j = 0; j < rgColumn.length; j++) {
            rgColumn[j].style.width = fixedRgCol[j].offsetWidth+"px";
          }
        }
      }
    </script>

效果:

解决列间空白间隙问题,可以按照以下步骤进行操作。首先,根据引用\[1\]的代码,可以使用`document.querySelector("html").style.height = `${window.innerHeight}px`;//适配手机端防止底部留白`来解决空白区域的留白问题。然后,根据引用\[2\]的代码,可以给固定列添加宽度来解决空白间隙问题。具体做法是在固定列的配置添加`{ width: 100, title: 'Action', key: 'operation', fixed: 'right', scopedSlots: { customRender: 'action' } }`。这样就可以解决列间空白间隙问题了。\[2\]\[3\] #### 引用[.reference_title] - *1* [解决网页、H5页面在手机端访问时,底部会有一段莫名其妙的空白,大约有几百像素高的留白](https://blog.csdn.net/qq_37860634/article/details/129983657)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] - *2* *3* [antd+vue表格固定列之后出现空白列-解决方案](https://blog.csdn.net/qq_43437571/article/details/108623666)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值