• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Smooth scroll - czysty JS

Object Storage Arubacloud
0 głosów
474 wizyt
pytanie zadane 8 grudnia 2018 w JavaScript przez povalor Nowicjusz (190 p.)
Witam, podjąłem próbę zrobienia smooth scroll w czystym JS, niestety napotkałem problem. Na stronie mam sticky menu. Gdy strona jest przesunięta na samą górę - smooth scroll działa, ale jeśli zjedziemy trochę w dół i klikniemy na odnośnik - smooth scroll nie działa i nie przenosi do odpowiedniej sekcji. Dlaczego?

Chcę to zrobić w czystym JS. Codepen: https://codepen.io/genghis/pen/roNaej

2 odpowiedzi

+1 głos
odpowiedź 9 grudnia 2018 przez Kamil Naja Nałogowiec (27,410 p.)
edycja 9 grudnia 2018 przez Kamil Naja
// początek funkcji
function scrollTo(element, e) {
  e.preventDefault();
...
//wywołanie
bottom.addEventListener('click', (e) => scrollTo(section3, e));


   to chyba będzie do zmiany, co drugie kliknięcie przenosi w inne miejsce.

top: element.getBoundingClientRect().top - 50

Wyjaśnienie - elementy middle i bottom są linkami, na kliknięcie wykonują domyślne akcje, które trzeba zablokować przez prevent default.

komentarz 9 grudnia 2018 przez povalor Nowicjusz (190 p.)

Dzięki, o to po części chodziło + jeszcze znalazłem rozwiązanie z tym, że co drugie kliknięcie przenosi w inne miejsce. Linijkę

top: element.getBoundingClientRect().top - 50

zmieniłem na

top: element.getBoundingClientRect().top - 50 + window.scrollY

 

0 głosów
odpowiedź 9 grudnia 2018 przez niezalogowany
przywrócone 9 grudnia 2018
Zdaje mi się, że getBoundingClientRect zwraca odległość względem widoku. Więc jeżeli jesteś na górze to pozycja będzie prawidłowa jednak gdy już zjedziesz na dół to odległość się zmniejszy a ty zostaniesz cofnięty w nieprawidłowe miejsce.

Podobne pytania

0 głosów
1 odpowiedź 560 wizyt
pytanie zadane 28 czerwca 2019 w JavaScript przez Mikołaj_627 Początkujący (480 p.)
0 głosów
1 odpowiedź 556 wizyt
pytanie zadane 23 maja 2018 w JavaScript przez Łucja Nowicjusz (120 p.)
0 głosów
1 odpowiedź 225 wizyt

92,555 zapytań

141,402 odpowiedzi

319,547 komentarzy

61,939 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...