ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

react 项目中 使用 antd 的 Table 实现列表的上拉加载

2022-08-10 17:37:06  阅读:197  来源: 互联网

标签:pageNum type react let scrollTop Table antd scrollHeight const


 

实现上拉加载 主要是通过计算 判断滚动条是否滚动到底部, 来进行触发加载事件的

 

需要注意的是 onScrollEvent 方法中所用到的变量, 不能 用 state 和 useState 来控制,  不能监听到他们的变化

 

元素宽高

(1)clientHeight、clientWidth→元素宽高(height+padding,不包含边框),可以理解为元素可视区域高度

(2)offsetHeight、offectWidth→元素宽高(height+padding+border,包含边框),可以理解为元素的可视高度

(3)scrollHeight、scrollWidth→元素宽高(内容的实际高度+上下padding<如果没有限制div的height,即height是自适应的,那么scrollHeight=clientHeight>)

(4)scrollHeight与offsetHeight的区别: offsetHeight即是自身的高度,scrollHeight是自身的高度+隐藏元素的高度(即是内层元素的offsetHeight)

 

滚动距离

(1)offsetTop:为容器相对于document的top的绝对偏移---→等于top+margin-top;同理offsetLeft:容器相对于document的left的绝对偏移---→等于left+margin-left

(2)clientTop: 容器内部相对于容器本身的top偏移,实际就是border-width

(3)scrollTop: Y轴的滚动条没有,或滚到最上时是0;Y轴的滚动条滚到最下时是 scrollHeight-clientHeight。滚动时通常只能scrollTop,当scrollTop为 0 到 scrollHeight-clientHeight 是正常的滚动距离,否则就是滚动过头了(手机上的阻尼效果)。

 

const ListComponent = () => {const [actList, setActList] = useState<any>([]);

  let lastScrollTop = 0;
  let pages = 0;
  let pageNum = 0;
  let loading = false;

  useEffect(() => {
    search('first');
    return () => {};
  }, []);

  const onScrollEvent = (e) => {
    if (loading) {
      return;
    }
    if (
      e.target.scrollTop + e.target.clientHeight >
      e.target.scrollHeight - 50
    ) {
      // 这里去做异步数据加载
      const pullDown = e.target.scrollTop - lastScrollTop > 0;
      if (pullDown && pageNum < pages) {
        loading = true;
        pageNum++;
        dispatchers.getList({ pageNum }).then(() => (loading = false));
      }
    }
    lastScrollTop = e.target.scrollTop;
  };

  // 多选
  const Selection = (row, type) => {
    let list = [...actList];
    if (type) {
      list.push(row.id);
    } else {
      const index = actList.findIndex((m) => m === row.id);
      list.splice(index, 1);
    }
    setActList(list);
  };

  // 查看转编辑
  const compile = () => {
    pageNum = 0;
    onMore('first');
  };

  // 搜索
  const search = (type: string) => {
    dispatchers.update({ params: {} });
    lastScrollTop = 0;
    pageNum = 0;
    onMore(type);
  };

  // 页面初始化获取列表 传 first是需要判断 第一页是否加载完已选中数据, 如果没有需要加载第二页
  let sltArr = [];
  const onMore = async (type: string) => {
    pageNum++;
    await dispatchers.getList({ pageNum }).then((res) => {
      if (type === 'first') {
        res.list.forEach((m) => {
          if (m.isGroup) {
            sltArr.push(m.id); // 选中数据
          }
        });
        if (history.location.state?.num / 20 > pageNum) {
          onMore(type);
        } else {
          setActList(sltArr);
        }
      }
      pages = res?.pages || 0;
      document.getElementsByClassName('ant-table-body')[0].scrollTop = 0;
      document
        .getElementsByClassName('ant-table-body')[0]
        .addEventListener('scroll', onScrollEvent);
    });
  };

  return (
    <div>
      <div className={css.act}>
        已选择 <span>{actList?.length}</span> 项,总数:
        {total} 人<span onClick={() => setActList([])}>清空</span>
      </div>
      <Table
        rowSelection={{
          onSelect: Selection,
          hideSelectAll: true,
          selectedRowKeys: actList,
        }}
        size="small"
        scroll={{ y: 570 }}
        className={'tableBox'}
        columns={columns}
        dataSource={state.list}
        pagination={false}
        rowKey="id"
      />
    </div>
  );
};

 

标签:pageNum,type,react,let,scrollTop,Table,antd,scrollHeight,const
来源: https://www.cnblogs.com/cielw/p/16573201.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有