• Jobs
  • About Us
  • professionals
    • Home
    • Jobs
    • Courses and challenges
  • business
    • Home
    • Post vacancy
    • Our process
    • Pricing
    • Assessments
    • Payroll
    • Blog
    • Sales
    • Salary Calculator

0

147
Views
¿Cómo coloco un elemento en el medio de una página y luego lo hago pegajoso y voy al principio?

Estoy tratando de colocar una barra de búsqueda en el medio de la página, no hay elementos encima, pero cuando estamos a punto de pasarla, quiero que se mantenga en la parte superior de la página.

La aplicación web se está desarrollando con REACT, no se permite usar JQuery.

Ejemplo:

Al abrir el sitio web, esta es la posición en la que debe estar

Posición inicial

Desplazando hacia abajo:

ingrese la descripción de la imagen aquí

Cuando la barra de búsqueda llega a la parte superior, se adhiere a ella:

ingrese la descripción de la imagen aquí

Aquí hay un poco de lo que he probado:

 .searchLink { flex-grow: 1; margin: 11px auto 11px auto; border-left-style: solid; border-left-width: 1px; border-left-color: var(--matterColorNegative); border: 1px solid #dddddd; border-radius: 50px; height: 50px; background-color: #ffffff; position: sticky; top: 0px; justify-content: center; @media (--viewportLarge) { max-width: 700px; padding-left: 0; }

No estoy seguro de cómo colocarlo en el medio de la página sin ningún elemento encima. El resultado del código actual hace que la barra de búsqueda aparezca en la parte superior de la página.

Soy un nuevo desarrollador web, estoy aprendiendo CSS. Por favor guíame.

about 3 years ago · Juan Pablo Isaza
2 answers
Answer question

0

Podrías probar algo como esto con un poco de código jquery

 window.addEventListener('load', function(){ var dinamicHeight = (window.innerHeight/2) - document.getElementById("myStickyBar").offsetHeight; document.getElementById("myMargin").style.height = dinamicHeight + "px"; }, false );
 #myStickyBar { height: 50px; width: 100%; background-color: red; position: sticky; top: 0; }
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script> <div style="height: 700px; width:100%;"> <div id="myMargin"></div> <div id="myStickyBar" style=""> </div> </div>

about 3 years ago · Juan Pablo Isaza Report

0

Tendrá que usar JavaScript para ver si se desplazó más allá del elemento. Una posible implementación podría verse así:

 <script> let initialPosition = null; window.addEventListener('scroll', (e) => { const searchbar = document.querySelector('.seachbar'); if (initialPosition && (window.scrollY < initialPosition)) { searchbar.classList.remove('sticky-top'); } else if (window.scrollY > (searchbar.offsetTop - searchbar.offsetHeight)) { if (!initialPosition) { initialPosition = searchbar.offsetTop - searchbar.offsetHeight; } searchbar.classList.add('sticky-top'); } }); </script>

Debe verificar si se ha desplazado más allá del elemento cada vez que se desplaza, por lo que debe adjuntar un detector de eventos al evento de desplazamiento de la ventana. Luego puede usar "window.scrollY" para verificar cuánto se desplazó el usuario hacia abajo y compararlo con el desplazamiento del elemento desde la parte superior de la página "element.offsetTop" y la altura del elemento "element.offsetHeight".

Entonces es simplemente una cuestión de agregar/eliminar una clase CSS al elemento con "posición: fija".

Tendrá que ajustar los selectores para que coincidan con su código, para esta implementación utilicé este ejemplo de CSS y HTML:

 <style> * { margin: 0; padding: 0; } .search-container { display: flex; justify-content: center; align-items: flex-end; height: calc(50vh - 50px); } .seachbar { width: 500px; height: 50px; border: 1px solid black; } .sticky-top { position: fixed; top: 25px; } .other-content { height: 100vh; } </style> <div class="search-container"> <div class="seachbar"> Search </div> </div> <div class="other-content"></div>
about 3 years ago · Juan Pablo Isaza Report
Answer question
Find remote jobs

Discover the new way to find a job!

Top jobs
Top job categories
Business
Post vacancy Pricing Our process Sales
Legal
Terms and conditions Privacy policy
© 2025 PeakU Inc. All Rights Reserved.

Andres GPT

Recommend me some offers
I have an error