Как установить таймер для функции прокрутки вверх

#javascript #html #css

#javascript #HTML #css

Вопрос:

У меня есть следующая простая scrollTop() функция, полученная из w3schools. Проблема, с которой я сталкиваюсь, заключается в установке времени для прокрутки. Разные люди предлагали разные методы, и все удалили одну или все строки из следующего кода. Я жду функции, которую можно добавить для установки скорости прокрутки, и никакой другой текст не должен быть удален. Вот работа с codepen https://codepen.io/vkdatta27/pen/zYqQbmM

 var mybutton = document.getElementById("myBtn");

window.onscroll = function() {
  scrollFunction()
};

function scrollFunction() {
  if (document.body.scrollTop > 20 || document.documentElement.scrollTop > 20) {
    mybutton.style.display = "block";
  } else {
    mybutton.style.display = "none";
  }
}

// When the user clicks on the button, scroll to the top of the document
function topFunction() {
  document.body.scrollTop = 0;
  document.documentElement.scrollTop = 0;
}  
 body {
  font-family: Arial, Helvetica, sans-serif;
  font-size: 20px;
}
#myBtn {
  display: none;
  position: fixed;
  bottom: 20px;
  right: 30px;
  z-index: 99;
  font-size: 18px;
  border: none;
  outline: none;
  background-color: red;
  color: white;
  cursor: pointer;
  padding: 15px;
  border-radius: 4px;
}
#myBtn:hover {
  background-color: #555;
}
html {
  scroll-behavior: smooth
}  
 <button onclick="topFunction()" id="myBtn" title="Go to top">Top</button>
<div style="background-color:black;color:white;padding:30px">Scroll Down</div>
<div style="background-color:lightgrey;padding:30px 30px 2500px">This example demonstrates how to create a "scroll to top" button that becomes visible
  <strong>when the user starts to scroll the page</strong></div>  

Комментарии:

1. добавить пример в codepen.io ?

2. когда я запускал ваш код, я не видел, чтобы появлялась кнопка «Top»

3. @dwosk, теперь проверь это.

4. Исправлено — вам нужно переместить <button>...</button> в начало файла. В противном случае myButton равно нулю, поскольку оно еще не создано.

5. Я не знаю точно, что вы ищете — вы смотрели window.scrollTo() ? Например: window.scrollTo({ top: 0, behavior: "smooth" });

Ответ №1:

Удалите функцию topFunction из вашей onclick="topFunction()" этой бесполезной утилиты и добавьте прослушиватель событий, чтобы нажать кнопку, вызывающую функцию для выполнения этого кода:

 mybutton.addEventListener("click", scrollTime);

async function scrollTime() {
    var time = 5; //seconds
    var y = document.documentElement.scrollTop; //get y position of scroll
    var duration = y/time; //calcule duration steps 
    while(y>0)
    {
        y = y-duration; //subtract by duration
        window.scrollTo({top: y, behavior: 'smooth'}); //move to position y
        await new Promise(res => setTimeout(res, 1000)); //await function with 1000 ms by steps
    }
}
  

Комментарии:

1. Да,. Понял, спасибо за ответ