#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. Да,. Понял, спасибо за ответ