记录一个Ant Design的表格,各列设置宽度值,固定列会多出空白列的问题

问题:

当使用Ant Design表格设置固定列,并且各列都设置固定宽度的时候,当屏幕宽度大于(你设置scroll:{x:xxx})x长度的时候,固定列会多出重复固定列

原因分析

设置固定列的时候是将固定列单独生成一个表格,固定在原表格的上方,将对应原表格的固定列遮住,形成固定效果。当屏幕宽度大于滚动长度也是表格的长度,原表格的固定列就会漏出,形成上图的效果

解决办法

方案一

选中一条非固定列,设置成不固定宽度(也就是将width删除)

注意:如果表头有分组的,要选择非分组列,否则可能将导致表头坍塌

方案二

监听页面的onsize的事件,获取window.innerWidth的,拿innerWidth和scroll的x值比较,如果innerWidth>scroll.x,就设置固定列为fixed,否则就不设置

kotlin 复制代码
....
、、一下为部分代码
import React from 'react';
import {debounce} from "lodash"

class MasterList extends React.Component {
  constructor(props) {
    super(props);
    this.state = {
      innerWidth:0
    };
    //设置防抖函数
    this.debounceFun=debounce(this.pageWdith,500)
  }

  componentDidMount = () => {
  //初始化宽口的值
    this.setState({
      innerWidth:window.innerWidth
    })
    //监听窗口变化
    window.addEventListener("resize",this.debounceFun)
    this.scrollx=tableScrollTable(this.columns)
  };

  //设置页面宽度
  pageWdith=(e)=>{
    this.setState({
      innerWidth:window.innerWidth
    })
  }
    //取消监听
  componentWillUnmount(){
    window.removeEventListener("resize",this.debounceFun)
  }

  render() {
    // 如果表格的宽度大于屏幕宽度就将最后的2列固定
    if(this.scrollx>this.state.innerWidth){
        this.columns[this.columns.length-1].fixed="right"
        this.columns[this.columns.length-2].fixed="right"
    }else{
        this.columns[this.columns.length-1].fixed=""
        this.columns[this.columns.length-2].fixed=""
    }
....
  }
}

export default Form.create()(MasterList);
相关推荐
兆子龙37 分钟前
像 React Hook 一样「自动触发」:用 Git Hook 拦住忘删的测试代码与其它翻车现场
前端·架构
兆子龙1 小时前
用 Auto.js 实现挂机脚本:从找图点击到循环自动化
前端·架构
SuperEugene1 小时前
表单最佳实践:从 v-model 到自定义表单组件(含校验)
前端·javascript·vue.js
昨晚我输给了一辆AE861 小时前
为什么现在不推荐使用 React.FC 了?
前端·react.js·typescript
不会敲代码11 小时前
深入浅出 React 闭包陷阱:从现象到原理
前端·react.js
不会敲代码11 小时前
React性能优化:深入理解useMemo和useCallback
前端·javascript·react.js
Dilettante2581 小时前
我的 Monorepo 实践经验:从基础概念到最佳实践
前端·前端工程化
只会cv的前端攻城狮2 小时前
Elpis-Core — 融合 Koa 洋葱圈模型实现服务端引擎
前端·后端
Java小卷2 小时前
流程设计器为啥选择diagram-js
前端·低代码·工作流引擎
HelloReader3 小时前
Isolation Pattern(隔离模式)在前端与 Core 之间加一道“加密网关”,拦截与校验所有 IPC
前端