Отслеживание видимости объектов, отображаемых в окне реакции
Я искал способ узнать, какой элемент списка виден на экране при использовании реагирующего окна.
Реквизит isVisible неправильно возвращает видимость.
https://codesandbox.io/s/bvaughnreact-window-fixed-size-list-vertical-nmukq
import React from "react";
import { render } from "react-dom";
import { FixedSizeList as List } from "react-window";
import AutoSizer from "react-virtualized-auto-sizer";
import TrackVisibility from "react-on-screen";
import "./styles.css";
const Row = ({ index, style, isVisible }) => (
<div className={index % 2 ? "ListItemOdd" : "ListItemEven"} style={style}>
Row {index + " is" + isVisible}
</div>
);
const RowWrapper = ({ index, style }) => (
<TrackVisibility>
<Row index={index} style={style} />
</TrackVisibility>
);
const Example = () => (
<AutoSizer>
{({ height, width }) => (
<List
className="List"
height={height}
itemCount={1000}
itemSize={35}
width={width}
>
{RowWrapper}
</List>
)}
</AutoSizer>
);
render(<Example />, document.getElementById("root"));
Возможно, это связано с кэшированием элементов, но мне было интересно, есть ли другой способ отслеживать видимость элемента
1 ответ
Я понял это самостоятельно. Пожалуйста, найдите код песочницы в
DynamicSizeList - https://codesandbox.io/s/piecykreact-window-dynamic-size-list-vertical-pooy2
Перехватывая событие onWheel и сравнивая "вершины" с clientHeight и ListHeight
FixedSizeList - https://codesandbox.io/s/bvaughnreact-window-fixed-size-list-vertical-nmukq
Также основано на событии onWheel.
Это не работает с реакцией на экране.
Если кто-то знает лучший способ сделать это, пожалуйста, ответьте.