微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

无限滚动的Mobx反应无法正确获取

如何解决无限滚动的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 举报,一经查实,本站将立刻删除。