我希望获得滚动到的每个div的ID,并将ID保持在我的状态。
我有一些div元素的列表。我希望将滚动到的div的当前ID存储在我的状态中。
我的代码
import React, { useEffect, useState } from "react";
export default function App() {
const [currentId, setCurrentId] = useState(null);
useEffect(() => {
// some code here
}, []);
return (
<>
<div style={{ height: 600, background: "#d7a1a1" }} id="div-1">
<h1>div 1</h1>
</div>
<div style={{ height: 600, background: "#d7a1a1" }} id="div-2">
<h1>div 2</h1>
</div>
<div style={{ height: 600, background: "#d7a1a1" }} id="div-3">
<h1>div 3</h1>
</div>
<div style={{ height: 600, background: "#d7a1a1" }} id="div-4">
<h1>div 4</h1>
</div>
<div style={{ height: 600, background: "#d7a1a1" }} id="div-5">
<h1>div 5</h1>
</div>
</>
);
}因此,当我滚动到第一个div时,我希望存储在currentId状态div-1中,到第二个div存储div-2等等。
发布于 2022-04-26 18:55:48
你可以这样做:
const [currentId, setCurrentId] = useState(null)
const [scrollPos, setScrollPos] = useState(0)
useEffect(() => {
window.addEventListener('scroll', setScrollPos(window.pageYOffset))
if(scrollPos <= 600) setCurrentId('div-1')
else if(scrollPos > 600 && scrollPos <= 1200) setCurrentId('div-2')
else if(scrollPos > 1200 && scrollPos <= 1800) setCurrentId('div-3')
// and so ....
return () => {
window.removeEventListener('scroll', handleScroll)
}
},[])https://stackoverflow.com/questions/72018841
复制相似问题