【antd】滚动触底加载分页

7 篇文章 0 订阅
2 篇文章 0 订阅
        //滚动计算
         let scrollRef: any
        //滚动加载下一页
        const onScrollCapture = e => {
          // scrollTop会有小数点导致等式不成立,解决方案:四舍五入
          if (Math.round(scrollRef.scrollTop) + scrollRef.clientHeight >=                     scrollRef.scrollHeight) {
            console.log("触发触底")
          }
         }

表格结构:

              {/* 表格---- */}
              <div
                className="table-body-contaier"
                onScrollCapture={onScrollCapture}
                style={{ height: 'calc(100vh - 150px)', overflowY: 'scroll' }}
                ref={c => {
                  scrollRef = c
                }}
              >
                <Table
                  dataSource={groupState.taskList}
                  columns={tableColumnsList}
                  pagination={false}
                  // scroll={{ y: 'calc(100vh - 135px)' }}
                  showHeader={false}
                  bordered={true}
                  size={'small'}
                  onRow={record => {
                    return {
                      onClick: e => {
                        e.stopPropagation()

                        console.log('点击行事件')
                      }, // 点击行
                    }
                  }}
                  rowClassName={(record: any, index: any) => {
                    if (record.flag == 1) {
                      return 'aaa'
                    } else {
                      return ''
                    }
                  }}
                />
              </div>

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
antd 中设置前端分页,可以使用 Table 组件的 pagination 属性。具体步骤如下: 1. 在 Table 组件中设置 dataSource 属性为数据数组,columns 属性为表格列的配置数组。 2. 设置 pagination 属性为一个对象,该对象包含以下属性: - current:当前页码,默认为 1。 - pageSize:每页显示的数量,默认为 10。 - total:总数据量,用于计算页数。 - onChange:页码改变的回调函数,可以在该函数中更新当前页码。 示例代码: ``` import { Table } from 'antd'; const dataSource = [ { id: 1, name: '张三', age: 18 }, { id: 2, name: '李四', age: 20 }, { id: 3, name: '王五', age: 22 }, // ... ]; const columns = [ { title: 'ID', dataIndex: 'id', key: 'id' }, { title: '姓名', dataIndex: 'name', key: 'name' }, { title: '年龄', dataIndex: 'age', key: 'age' }, // ... ]; function MyTable() { const [pagination, setPagination] = useState({ current: 1, pageSize: 10, total: dataSource.length, onChange: (page) => { setPagination({ ...pagination, current: page }); }, }); const start = (pagination.current - 1) * pagination.pageSize; const end = start + pagination.pageSize; const displayedData = dataSource.slice(start, end); return ( <Table dataSource={displayedData} columns={columns} pagination={pagination} /> ); } ``` 在上面的示例中,我们使用 useState 来保存 pagination 对象,并根据当前页码和每页显示的数量来计算需要显示的数据。在 Table 组件中,我们将 dataSource 设置为 displayedData,也就是经过分页后的数据,pagination 设置为我们保存的 pagination 对象。当页码改变时,我们更新 current 属性,并重新计算需要显示的数据。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值