• Empleos
  • Sobre nosotros
  • profesionales
    • Inicio
    • Empleos
    • Cursos y retos
  • empresas
    • Inicio
    • Publicar vacante
    • Nuestro proceso
    • Precios
    • Evaluaciones
    • Nómina
    • Blog
    • Comercial
    • Calculadora de salario

0

216
Vistas
ReactJS, onScroll no funciona para la barra de navegación dinámica

Estoy tratando de hacer que una barra de navegación sea visible solo cuando el usuario pasa la sección del encabezado. Configuré una función simple para que se active con "onScroll". Sin embargo, en realidad no está funcionando.

Componente:

 function App() { const [productArray, setProductArray] = useState([]); const [navBarClass, setNavBarClass] = useState("hidden"); const navBarScroll = () => { setNavBarClass("visible"); }; // this should make the navbar visible return ( <div className="App"> <Header onScroll={navBarScroll} /> // Here's the onScroll <ProductContainer productArray={productArray} setProductArray={setProductArray} /> <About /> <Footer /> <NavBar className={navBarClass} /> // This is the nav bar </div> ); }

Componente de encabezado:

 const Header = () => { return ( <div className="header" id="home"> <div className="header-sub"> <div className="div-1"> <img src={logo} alt="logo" className="logo" /> <div className="menu"> <a href="#home">Home</a> <a href="#about">About</a> <a href="#shop">Shop</a> <a href="mailto:example@gmail.com">Contact</a> <ShoppingCartIcon className="btn" /> <p></p> </div> </div> <div className="div-2"> <FadeIn transitionDuration="2500"> <h1>AS UNIQUE AS YOU ARE.</h1> </FadeIn> </div> <div className="div-3"></div> </div> </div> ); };
almost 3 years ago · Juan Pablo Isaza
1 Respuestas
Responde la pregunta

0

El problema es que onScroll no se consume en el componente de Header . Necesitamos agregar el evento onScroll en la etiqueta HTML para que se invoque.

Puede leer onScroll prop en el componente Header y pasarlo al div principal como se muestra a continuación y debería llamarse:

 const Header = ({onScroll}) => { return ( <div className="header" id="home" onScroll={onScroll}> <div className="header-sub"> <div className="div-1"> <img src={logo} alt="logo" className="logo" /> <div className="menu"> <a href="#home">Home</a> <a href="#about">About</a> <a href="#shop">Shop</a> <a href="mailto:example@gmail.com">Contact</a> <ShoppingCartIcon className="btn" /> <p></p> </div> </div> <div className="div-2"> <FadeIn transitionDuration="2500"> <h1>AS UNIQUE AS YOU ARE.</h1> </FadeIn> </div> <div className="div-3"></div> </div> </div> ); };
almost 3 years ago · Juan Pablo Isaza Denunciar
Responde la pregunta
Encuentra empleos remotos

¡Descubre la nueva forma de encontrar empleo!

Top de empleos
Top categorías de empleo
Empresas
Publicar vacante Precios Nuestro proceso Comercial
Legal
Términos y condiciones Política de privacidad
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recomiéndame algunas ofertas
Necesito ayuda