如何解决无限滚动的Mobx反应无法正确获取
我在元素底部向下滚动后尝试获取数据。当我滚动时这部分正在工作,但是行为不正确。提取时,数据会渲染很多次,而且顺序也不正确。在滚动之前看起来还不错。它不应该那样做。我正在使用MobX。
问题一定是由于某种原因引起的:
componentDidMount() {
const { listData } = this.props;
const { data = [] } = listData;
const rowData = [...data].reverse();
this.ref.current.addEventListener('scroll',this.handleScroll,false);
this.handleScroll();
reaction(
() => rowData,() => this.handleScroll()
); }
渲染如下:
render() {
const { listData } = this.props;
const { data = [] } = listData;
const rowData = [...data].reverse();
return (
<>
<div className="container" ref={this.ref}>
<ul className="list">
{_.map(rowData,(item,index) => (
<li
className="some-list"
key={index}
>
<div className="item-wrapper">
<div className="item">
<div className="item-name">
List {item.number}
</div>
</div>
</div>
</li>
))}
</ul>
</div>
</>
手柄滚动的代码:
handleScroll() {
const { listData } = this.props;
const { paging = [] } = listData;
const contentHolder = this.ref.current;
const margin = 100;
const scrollY = contentHolder.scrollTop;
const wrapperHeight = contentHolder.offsetHeight;
const list = contentHolder.querySelector('.container');
if (wrapperHeight + scrollY >= list.offsetHeight - margin) {
this.handleRecieveFetch(paging.next);
}
}
代码在同一组件中。 你有什么想法我做错了吗?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。