antd table 滚动到指定行方法

本文介绍了一种在React应用中实现表格特定行高亮显示并自动滚动至该行的技术方案。通过设置行样式和计算高亮行位置,确保用户能够快速定位到关注的数据行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、找到指定的行,并高亮

<div id={'tableList'}>
    <Table bordered 
            dataSource={data}
            pagination={false}
            rowClassName={this.setClassName}
            columns={this.columns}
            scroll={{ y: 440 }}/>
</div>

//设置行样式

    setClassName = (record, index) => {
        if(record.id == this.state.currId){
            return `row${index} ${styles.highlight}`; //highlight样式需要自己定义
        }
        return `row${index}`;
    }

2、滚动条滚动到高亮行位置

    
    //调用getRowHeightAndSetTop方法获取高亮行的index值后,通过setScrollTopValue设置滚动条位置
    //data:table的datasource数据
    //value:当前需要高亮的值
    getRowHeightAndSetTop(data, value){
        data && data.forEach((item, index) => {
            if(item.id == value){
                this.setTableScrollTop(index);
            }
        })
    }
    //设置滚动条位置的方法
    setTableScrollTop(index){
        if (index != 0 || index != -1){
            //40是一行的高度,index*40就是滚动条要移动的位置
            let currPosition = index * 40;
            $(`#list .ant-table-body`).scrollTop(currPosition);
        }
    }

 

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值