首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >无限滚动上行更新的RxJS轮询

无限滚动上行更新的RxJS轮询
EN

Stack Overflow用户
提问于 2016-02-21 09:14:54
回答 1查看 937关注 0票数 16

我在https://www.youtube.com/watch?v=zlERo_JMGCw 29:38看Matthew Podwysocki的活动

他解释了他们是如何在netflix上解决滚动问题的。当先前的数据被清理并累积更多数据时,用户滚动获取更多数据(但回滚会再次显示先前的数据)。

我也想做类似的事情,但我抓取了netflix的演示代码:

代码语言:javascript
复制
function getRowUpdates(row) {
  var scrolls = Rx.Observable.fromEvent(document, 'scroll');
  var rowVisibilities = 
    scrolls.throttle(50)
      .map(function(scrollEvent) {
        return row.isVisible(scrollEvent.offset);
      })
      .distinctUntilChanged();

  var rowShows = rowrowVisibilities.filter(function(v) {
    return v;
  });
  var rowHides = rowrowVisibilities.filter(function(v) {
    return !v;
  });

  return rowShows
    .flatMap(Rx.Observable.interval(10))
    .flatMap(function() {
      return row.getRowData().takeUntil(rowHides);
    })
    .toArray();
}

但我对如何根据此处的滚动条传递新数据或页面数据感到有点困惑。有没有人可以解释一下我是如何做到以下几点的:

  • fetch first list (我可以这样做)
  • fetch more list as user scroll (使用翻页到下一页)
  • 从内存中删除以前提取的数据,并根据请求重新获取(向上滚动)。
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/35531128

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档