【问题标题】:React: How to use arrow up/down to select previous/next item in a scroll list and make the list scroll to keep the selected element on screenReact:如何使用向上/向下箭头选择滚动列表中的上一个/下一个项目并使列表滚动以将所选元素保留在屏幕上
【发布时间】:2017-08-15 23:27:38
【问题描述】:

我正在使用 react-infinite 滚动列表,并且我实现了一个向上/向下箭头处理程序:

onKeyDown = (e) => {
    if(e.keyCode === 40){
        if (this.props.onKeyDown) {
            e.preventDefault()
            this.props.onKeyDown()
        }
    }
    else if (e.keyCode === 38) {
        if (this.props.onKeyUp) {
            e.preventDefault()
            this.props.onKeyUp()
        }
    }
}

(该组件可在整个应用程序中重复使用,因此我通过 props 传递实际功能)

这适用于选择列表中的下一个/上一个项目。但是当您到达滚动列表的边缘并继续前进时,列表不会滚动以使所选项目保持在视图中。选定的项目会从屏幕上消失。

任何帮助将不胜感激!

【问题讨论】:

  • 你有我们的onkeyup和-down功能吗?这样我就可以让我的答案更加量身定制。

标签: javascript html css reactjs web-deployment


【解决方案1】:

您需要方法scrollIntoView。它存在于每个元素上。您还需要通过获取元素的offsetTop 并与组件的offsetHeight 进行比较来检测元素何时呈现在屏幕外,当此数字高于组件的offsetHeight 时,您需要将其滚动到视图中。

【讨论】:

  • 这绝对让我很接近。不幸的是,react-infinite 组件不像普通的滚动。例如,我的 offsetHeight 是 20。但我的 offsetTop 始终是数百个。我还在玩scrollIntoView,不过……它几乎可以工作了。这与我现在设置它的方式真的很矛盾并且不一致。 let elem = document.getElementById('selected')elem.scrollIntoView({block: "start", behavior: "smooth"})
  • 这些东西很难正确设置,但如果做得好,还是值得的。这需要大量的尝试和错误。
猜你喜欢
  • 2016-01-03
  • 1970-01-01
  • 2012-01-16
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 1970-01-01
  • 2018-10-23
相关资源
最近更新 更多