首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何获得我滚动到的div的ID?

如何获得我滚动到的div的ID?
EN

Stack Overflow用户
提问于 2022-04-26 18:28:12
回答 1查看 362关注 0票数 3

我希望获得滚动到的每个div的ID,并将ID保持在我的状态。

我有一些div元素的列表。我希望将滚动到的div的当前ID存储在我的状态中。

我的代码

代码语言:javascript
复制
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等等。

EN

回答 1

Stack Overflow用户

发布于 2022-04-26 18:55:48

你可以这样做:

代码语言:javascript
复制
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)
    }
},[])
票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72018841

复制
相关文章

相似问题

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