JavaScript - кнопка прокрутки к началу страницы
Данное решение от AI использует код HTML, Javascript и стили CSS.
Запрос к AI: Нужно решение на js css для прокрутки страницы сайта к верхней кромке, типа кнопки “Home” на клавиатуре.
При прокрутке вниз на 100px появляется в нижнем левом углу страницы кнопка со стрелкой вверх.
При нажатии на кнопку идёт анимированная прокрутка вверх страницы и кнопка исчезает.
Кнопка современно стилизировать.
Ответ от AI: Вот готовое решение с современным дизайном и плавной анимацией:
Файл демонстрации:
HTML
<!DOCTYPE html>
<html lang="ru">
<head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title>Кнопка прокрутки вверх</title>
<link rel="stylesheet" href="styles.css">
</head>
<body>
<!-- Контент для прокрутки -->
<div class="content">
<h1>Прокрутите вниз, чтобы увидеть кнопку</h1>
<div class="spacer"></div>
</div>
<!-- Кнопка прокрутки вверх -->
<button id="scrollToTopBtn" class="scroll-to-top" aria-label="Прокрутить вверх">
<svg class="arrow-icon" viewBox="0 0 24 24" width="24" height="24" fill="none" stroke="currentColor" stroke-width="2.5" stroke-linecap="round" stroke-linejoin="round">
<path d="M18 15l-6-6-6 6"/>
</svg>
</button>
<script src="script.js"></script>
</body>
</html>CSS (styles.css)
CSS
* {
margin: 0;
padding: 0;
box-sizing: border-box;
}
body {
font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
min-height: 200vh;
background: linear-gradient(135deg, #667eea 0%, #764ba2 100%);
color: white;
}
.content {
max-width: 800px;
margin: 0 auto;
padding: 2rem;
text-align: center;
}
.content h1 {
font-size: 2.5rem;
margin-bottom: 2rem;
text-shadow: 2px 2px 4px rgba(0,0,0,0.3);
}
.spacer {
height: 150vh;
}
/* Стили кнопки */
.scroll-to-top {
position: fixed;
bottom: 2rem;
left: 2rem;
width: 56px;
height: 56px;
border-radius: 16px;
background: rgba(255, 255, 255, 0.9);
backdrop-filter: blur(10px);
border: 2px solid rgba(255, 255, 255, 0.3);
box-shadow: 0 8px 32px rgba(31, 38, 135, 0.37);
cursor: pointer;
display: flex;
align-items: center;
justify-content: center;
opacity: 0;
visibility: hidden;
transform: translateY(20px) scale(0.8);
transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
z-index: 1000;
color: #667eea;
}
.scroll-to-top.visible {
opacity: 1;
visibility: visible;
transform: translateY(0) scale(1);
}
.scroll-to-top:hover {
background: white;
transform: translateY(-4px) scale(1.05);
box-shadow: 0 12px 40px rgba(31, 38, 135, 0.5);
border-color: rgba(255, 255, 255, 0.6);
}
.scroll-to-top:active {
transform: translateY(0) scale(0.95);
box-shadow: 0 4px 16px rgba(31, 38, 135, 0.3);
}
.scroll-to-top:focus-visible {
outline: 3px solid #764ba2;
outline-offset: 3px;
}
.arrow-icon {
width: 28px;
height: 28px;
transition: transform 0.3s ease;
}
.scroll-to-top:hover .arrow-icon {
transform: translateY(-2px);
}
/* Анимация при нажатии */
@keyframes clickPulse {
0% {
transform: scale(1);
}
50% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
}
.scroll-to-top:active {
animation: clickPulse 0.3s ease;
}
/* Стили для мобильных устройств */
@media (max-width: 768px) {
.scroll-to-top {
width: 48px;
height: 48px;
bottom: 1.5rem;
left: 1.5rem;
}
.arrow-icon {
width: 24px;
height: 24px;
}
}JavaScript (script.js)
JS
document.addEventListener('DOMContentLoaded', function() {
const scrollToTopBtn = document.getElementById('scrollToTopBtn');
const scrollThreshold = 100; // пиксели, при достижении которых кнопка появляется
// Функция для проверки положения прокрутки
function toggleButtonVisibility() {
if (window.scrollY > scrollThreshold) {
scrollToTopBtn.classList.add('visible');
} else {
scrollToTopBtn.classList.remove('visible');
}
}
// Функция плавной прокрутки вверх
function scrollToTop() {
const startPosition = window.scrollY;
const duration = 600; // длительность анимации в мс
const startTime = performance.now();
function easeInOutQuad(t) {
return t < 0.5 ? 2 * t * t : -1 + (4 - 2 * t) * t;
}
function animateScroll(currentTime) {
const elapsed = currentTime - startTime;
const progress = Math.min(elapsed / duration, 1);
const easedProgress = easeInOutQuad(progress);
window.scrollTo(0, startPosition * (1 - easedProgress));
if (progress < 1) {
requestAnimationFrame(animateScroll);
} else {
// Кнопка исчезает после завершения прокрутки
scrollToTopBtn.classList.remove('visible');
}
}
requestAnimationFrame(animateScroll);
}
// Слушаем событие прокрутки
window.addEventListener('scroll', () => {
requestAnimationFrame(toggleButtonVisibility);
}, { passive: true });
// Слушаем клик по кнопке
scrollToTopBtn.addEventListener('click', scrollToTop);
// Проверяем начальное положение
toggleButtonVisibility();
});Особенности реализации:
🎨 Современный дизайн:
- Стеклянный эффект (glassmorphism) с размытием фона
- Плавные градиенты и тени
- Иконка стрелки вверх в виде SVG
- Анимация при наведении и нажатии
- Адаптация под мобильные устройства
✨ Функциональность:
- Кнопка появляется после прокрутки на 100px
- Плавная анимация прокрутки с easing-функцией easeInOutQuad
- Кнопка исчезает после завершения прокрутки
- Оптимизация производительности через requestAnimationFrame
- Поддержка клавиатурной навигации (focus-visible)
🚀 Производительность:
- Использование
requestAnimationFrameдля плавной анимации - Пассивный слушатель событий (
{ passive: true }) - CSS transitions для аппаратного ускорения
Просто скопируйте код в соответствующие файлы и откройте HTML в браузере!
Дата публикации:ТОП 10 случайных публикаций
Сайт разработан студией © WEB-VidST
