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   


Яндекс.Метрика
×