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

Smooth scroll

42 Warsaw Coding Academy
0 głosów
751 wizyt
pytanie zadane 28 czerwca 2019 w JavaScript przez Mikołaj_627 Początkujący (480 p.)

Cześć,

Niedawno na podstawie poradnika zrobiłem efekt smooth scroll na swojej stronie ale mam problem ponieważ jeśli chodzi o przewijanie z góry na dół wszystko działa poprawnie, jednak kiedy przewijam z dołu do góry to zamiast przenieść mnie do odpowiedniej sekcji przenosi mnie na samą górę, oto poradnik a to kod 

function smoothScroll(target, duration) {
  var target = document.querySelector(target);
  var targetPosition = target.getBoundingClientRect().top;
  var startPosition = window.pageYOffset;
  var distance = targetPosition - startPosition;
  var startTime = null;

  function animation(currentTime) {
    if (startTime === null) startTime = currentTime;
    var timeElapsed = currentTime - startTime;
    var run = ease(timeElapsed, startPosition, distance, duration);
    window.scrollTo(0, run);
    if (timeElapsed < duration) requestAnimationFrame(animation);
  }

  function ease(t, b, c, d) {
    t /= d / 2;
    if (t < 1) return (c / 2) * t * t + b;
    t--;
    return (-c / 2) * (t * (t - 2) - 1) + b;
  }

  requestAnimationFrame(animation);

  console.log(startPosition);
}

let btn = document.querySelectorAll(".service-btn");
let buttons = btn.length;
let footerbtn = document.querySelector(".footer-btn");

for (let i = 0; i < buttons; i++) {
  btn[i].addEventListener("click", function() {
    smoothScroll(".services", 1000);
  });
}

footerbtn.addEventListener("click", function() {
  smoothScroll(".services", 1000);
});

 

1 odpowiedź

0 głosów
odpowiedź 28 czerwca 2019 przez Chess Szeryf (76,730 p.)
edycja 28 czerwca 2019 przez Chess

Ustaw licznik odpowiedzialny za to, w którym miejscu się znajdujesz. Gdy jesteś na samym dole, licznik zapewne jest ustawiony np. na 0 - oznacza, to że gdy naciśniesz na coś, to wtedy jesteś przenoszony na samą górę. Po ustawieniu licznika na odpowiednią wartość, powinieneś być przeniesiony z dołu do góry zgodnie z wartościami w liczniku.

Np. poglądowo mogłoby to wyglądać tak: 0 - góra, 1 - środek, 2 - dół.

Jeśli jesteś na samym dole (2), to licznik widzi, że jesteś na tej sekcji. Jeśli naciśniesz na sekcję numer 0, to wtedy powienien przenieść Cię do góry. Teraz jest tak chyba, że gdy zjedziesz na sam dół (2), to automatyczenia zmienia się wartość licznika na 0 i później jak klikasz, to przenosi Cię do sekcji (0) zamiast np. do sekcji (1).

Licznik - mam na myśli wartość pozycji scroll'a w uproszczeniu.

<body style="background: darkolivegreen; margin: 0; padding: 0;">

<div style="position: fixed; right: 0;">
  <button id="to_section">to_section: </button>
  <input type="text" id="section_x"/>
</div>

<div id="section1">s1</div>
<div id="section2" style="margin-top: 1000px;">s2</div>
<div id="section3" style="margin-top: 2450px;">s3</div>
document.getElementById('to_section').addEventListener('click', function() {
 
  if(document.getElementById(document.getElementById('section_x').value) != undefined) {

    let target_position = document.getElementById(document.getElementById('section_x').value).getBoundingClientRect().top;
    let start_position = window.pageYOffset;
    let distance = target_position - start_position;
   
    window.scrollTo({
      top: distance,
      behavior: 'smooth'
    });
  
  }

}, false);
</body>

Podobne pytania

0 głosów
2 odpowiedzi 557 wizyt
pytanie zadane 8 grudnia 2018 w JavaScript przez povalor Nowicjusz (190 p.)
0 głosów
1 odpowiedź 888 wizyt
pytanie zadane 23 maja 2018 w JavaScript przez Łucja Nowicjusz (120 p.)
0 głosów
1 odpowiedź 195 wizyt

93,377 zapytań

142,380 odpowiedzi

322,532 komentarzy

62,727 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

VMware Cloud PRO - przenieś swoją infrastrukturę IT do chmury
...