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

Scroll to bottom?

Object Storage Arubacloud
0 głosów
101 wizyt
pytanie zadane 29 grudnia 2019 w JavaScript przez BlvckFox Gaduła (4,240 p.)

Cześć, jak można przerobić ten kod: https://codepen.io/FoxCode/pen/KKwvGjQ 
Na taki, żeby przycisk "down-btn" działał na tej samej zasadzie (taki smootch scroll), tylko, że na dół strony?

1 odpowiedź

+1 głos
odpowiedź 29 grudnia 2019 przez Tomek Sochacki Ekspert (227,510 p.)
wybrane 29 grudnia 2019 przez BlvckFox
 
Najlepsza
const downBtn = document.querySelector('.down-btn');

downBtn.addEventListener('click', () => {
    document.body.scrollIntoView({behavior: 'smooth', block: 'end', inline: 'nearest'});
})

analogicznie dla top też użyłbym tej metody, tylko w block ustaw wtedy "start". Nie widzę za bardzo sensu bawienia się w ten dziwne obliczenia i scrollTop. To jest wg mnie wygodniejsze i czytelniejsze.

komentarz 29 grudnia 2019 przez BlvckFox Gaduła (4,240 p.)
O boże, nie widziałem, że istnieje coś tak prostego! Na pierwszych stronach stackoverflow są właśnie jakieś liczenia, sprawdzanie co sekundę gdzie się znajduje użytkownik itd.
Mam jeszcze jedno pytanie, czy istnieje też jakiś prostszy sposób na np. ukrycie przycisku 'bottom' gdy zbliża się do końca? Np. 100px przed końcem strony. (Ja raczej bym kombinował z użyciem eventListener onscroll.
komentarz 29 grudnia 2019 przez Tomek Sochacki Ekspert (227,510 p.)

tu już sytuacja jest nieco inna... są dwie drogi, można standardowo obsługiwać event scroll dla window i w zależności od pozycji usera usuwac/pokazywac button albo pobawić się w intersection observer, ale z tym trzeba uważać żeby dobrze to działało też na wszystkich mobilkach (iOS itp.). Generalnie jeśli to jakaś prosta stronka to zostałbym przy tradycyjnym scrollu:

window.addEventListener('scroll', () => {
  const offset = window.innerHeight + window.pageYOffset;
  const showButton = offset >= document.body.scrollHeight;
  button.classList.toggle('show', showButton);
});

to mógłby być kod dla ukrywania buttona do przewijania w górę, czyli pokazanie go dopiero, gdy user zobaczy ostatni element na stronie, ewentualnie można tu sobie w tym warunku dodać jakieś dodatkowe PX. Dla buttona drugiego byłoby podobnie.

komentarz 29 grudnia 2019 przez BlvckFox Gaduła (4,240 p.)
Ok, a istnieje jeszcze jakaś opcja, która pozwoli mi np. zamiast bloku "end" zrobić coś takiego jak "end+200px"? W sensie, chciałbym, żeby scroll był na 200px przed końcem.

Podobne pytania

0 głosów
1 odpowiedź 112 wizyt
pytanie zadane 23 kwietnia 2019 w JavaScript przez iframeeh Użytkownik (680 p.)
0 głosów
0 odpowiedzi 96 wizyt
pytanie zadane 18 stycznia 2019 w HTML i CSS przez mb-dir Mądrala (6,710 p.)
+1 głos
3 odpowiedzi 139 wizyt
pytanie zadane 11 lipca 2020 w JavaScript przez Mikes_Pl Nowicjusz (180 p.)

92,579 zapytań

141,432 odpowiedzi

319,664 komentarzy

61,965 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!

...