Javascript.RU

Создать новую тему Ответ
 
Опции темы Искать в теме
  #11 (permalink)  
Старый 05.06.2023, 07:22
Аватар для voraa
Профессор
Отправить личное сообщение для voraa Посмотреть профиль Найти все сообщения от voraa
 
Регистрация: 03.02.2020
Сообщений: 2,748

Сообщение от Сергей Ракипов
Это шутка такая? Просто я понимаю что нет таких настроек как плавность в браузере
В режиме энергосбережения в Хроме плавная прокрутка отключается
Ответить с цитированием
  #12 (permalink)  
Старый 05.06.2023, 10:10
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,118

плавный скроллинг к блоку requestAnimationFrame
Сергей Ракипов,
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            font-family: 'Courier New', Courier, monospace;
            font-size: 16px;
        }

        section {
            height: 600px;
            padding: 0px 0px 0px 60px;
            font-weight: bold;
            border: 1px solid #8B4513;
        }

        header {
            height: 600px;
        }

        footer {
            height: 600px;
        }

        nav {
            position: fixed;
            top: 30px;
            left: 8px;
            right: 0px;
        }

        .nav_up {
            height: 50px;
            width: 50px;
            display: flex;
            justify-content: center;
            align-items: center;
            background-color: #98FB98;
            color: #fff;
            font-size: 25px;
            cursor: pointer;
        }

        .nav_down {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 50px;
            width: 50px;
            background-color: #755D9A;
            color: #fff;
            font-size: 24px;
            cursor: pointer;
        }

        .not_found {
            opacity: .2;
        }
    </style>
</head>

<body>
    <nav>
        <div class="nav_up">
            &uArr;
        </div>
        <div class="nav_down">
            &dArr;
        </div>
    </nav>
    <header>
        Шапка
    </header>
    <section>
        Блок 1
    </section>
    <section>
        Блок 2
    </section>
    <section>
        Блок 3
    </section>
    <section>
        Блок 4
    </section>
    <section>
        Блок 5
    </section>
    <section>
        Блок 6
    </section>
    <section>
        Блок 7
    </section>
    <section>
        Блок 8
    </section>
    <footer>
        Подвал
    </footer>
    <script>
        const sections = document.querySelectorAll("section");
        const navUp = document.querySelector(".nav_up");
        const navDown = document.querySelector(".nav_down");

        function anim(speed) {
            let temp;
            return function(elem) {
                cancelAnimationFrame(temp);
                let start = performance.now();
                let from = window.pageYOffset || document.documentElement.scrollTop,
                    to = elem.getBoundingClientRect().top;
                let duration = Math.abs(to) * speed;
                requestAnimationFrame(function step(timestamp) {
                    let progress = (timestamp - start) / duration;
                    1 <= progress && (progress = 1);
                    window.scrollTo(0, from + to * progress | 0);
                    1 > progress && (temp = requestAnimationFrame(step))
                })
            }
        };
        const smooth = anim(1.8);

        function getCurrentIndex() {
            let currentIndex = 0,
                arr = Array.from(sections);
            let item = arr.slice(0).sort(function(a, b) {
                return Math.abs(a.getBoundingClientRect().top) - Math.abs(b.getBoundingClientRect().top);
            })[0];
            currentIndex = arr.indexOf(item);
            return currentIndex;
        }

        function scrollToSection(direction) {
            const currentIndex = getCurrentIndex();
            let nextIndex;
            if (direction === "up") {
                nextIndex = Math.max(currentIndex - 1, 0);
            } else if (direction === "down") {
                nextIndex = Math.min(currentIndex + 1, sections.length - 1);
            }
            smooth(sections[nextIndex]);
        }
        // обработчики для кнопок
        navUp.addEventListener("click", () => {
            scrollToSection("up");
        });
        navDown.addEventListener("click", () => {
            scrollToSection("down");
        });
        // обработчики для клавиш вверх и вниз
        document.addEventListener("keydown", (event) => {
            event.preventDefault();
            if (event.code === "ArrowUp") {
                scrollToSection("up");
            } else if (event.code === "ArrowDown") {
                scrollToSection("down");
            }
        });
        window.addEventListener("scroll", () => {
            const currentIndex = getCurrentIndex();
            const show = Math.abs(sections[currentIndex].getBoundingClientRect().top) < 1;
            navUp.classList.toggle("not_found", !currentIndex && show);
            navDown.classList.toggle("not_found", currentIndex == sections.length - 1 && show);
        })
    </script>
</body>

</html>

Последний раз редактировалось рони, 05.06.2023 в 16:40. Причина: изменена скорость прокрутки
Ответить с цитированием
  #13 (permalink)  
Старый 05.06.2023, 15:58
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 668

Сообщение от voraa Посмотреть сообщение
В режиме энергосбережения в Хроме плавная прокрутка отключается
не знал, спасибо
Ответить с цитированием
  #14 (permalink)  
Старый 05.06.2023, 16:34
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 668

рони,
А как условия тут работают, хотя бы в двух словах.
Просто когда загружается страница кнопка вверх он активна и ее можно нажать. а по идеи не должна быть потому что вверху нету блоков
тоже самое внизу тоже можно нажать еще раз вниз и придешь снова 8 блок хотя по идее внизу нету больше блоков
Ответить с цитированием
  #15 (permalink)  
Старый 05.06.2023, 16:45
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,118

Сергей Ракипов,
условия для кнопок на данный момент, фиксируют только факт достижения первого или последнего блока.
Ответить с цитированием
  #16 (permalink)  
Старый 05.06.2023, 17:41
Аватар для рони
Профессор
Отправить личное сообщение для рони Посмотреть профиль Найти все сообщения от рони
 
Регистрация: 27.05.2010
Сообщений: 33,118

Сергей Ракипов,
класс и работа кнопки зависят от наличия блоков далее, согласно направлению.
<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            font-family: 'Courier New', Courier, monospace;
            font-size: 16px;
        }

        section {
            height: 600px;
            padding: 0px 0px 0px 60px;
            font-weight: bold;
            border: 1px solid #8B4513;
        }

        header {
            height: 600px;
        }

        footer {
            height: 600px;
        }

        nav {
            position: fixed;
            top: 30px;
            left: 8px;
            right: 0px;
        }

        .nav_up {
            height: 50px;
            width: 50px;
            display: flex;
            justify-content: center;
            align-items: center;
            background-color: #98FB98;
            color: #fff;
            font-size: 25px;
            cursor: pointer;
        }

        .nav_down {
            display: flex;
            justify-content: center;
            align-items: center;
            height: 50px;
            width: 50px;
            background-color: #755D9A;
            color: #fff;
            font-size: 24px;
            cursor: pointer;
        }

        .not_found {
            opacity: .2;
        }
    </style>
</head>

<body>
    <nav>
        <div class="nav_up">
            &uArr;
        </div>
        <div class="nav_down">
            &dArr;
        </div>
    </nav>
    <header>
        Шапка
    </header>
    <section>
        Блок 1
    </section>
    <section>
        Блок 2
    </section>
    <section>
        Блок 3
    </section>
    <section>
        Блок 4
    </section>
    <section>
        Блок 5
    </section>
    <section>
        Блок 6
    </section>
    <section>
        Блок 7
    </section>
    <section>
        Блок 8
    </section>
    <footer>
        Подвал
    </footer>
    <script>
        const sections = document.querySelectorAll("section");
        const navUp = document.querySelector(".nav_up");
        const navDown = document.querySelector(".nav_down");

        function anim(speed) {
            let temp;
            return function(elem) {
                cancelAnimationFrame(temp);
                let start = performance.now();
                let from = window.pageYOffset || document.documentElement.scrollTop,
                    to = elem.getBoundingClientRect().top;
                let duration = Math.abs(to) * speed;
                requestAnimationFrame(function step(timestamp) {
                    let progress = (timestamp - start) / duration;
                    1 <= progress && (progress = 1);
                    window.scrollTo(0, from + to * progress | 0);
                    1 > progress && (temp = requestAnimationFrame(step))
                })
            }
        };
        const smooth = anim(1.8);

        function getCurrentIndex() {
            let currentIndex = 0,
                arr = Array.from(sections);
            if(sections[0].getBoundingClientRect().top >= 5) return -1;
            if(sections[sections.length - 1].getBoundingClientRect().top <= -5) return sections.length;
            let item = arr.slice(0).sort(function(a, b) {
                return Math.abs(a.getBoundingClientRect().top) - Math.abs(b.getBoundingClientRect().top);
            })[0];
            currentIndex = arr.indexOf(item);
            return currentIndex;
        }

        function scrollToSection(direction) {
            const currentIndex = getCurrentIndex();
            let nextIndex;
            if (direction === "up") {
            if(navUp.classList.contains('not_found')) return;
                nextIndex = Math.max(currentIndex - 1, 0);
            } else if (direction === "down") {
                if(navDown.classList.contains('not_found')) return;
                nextIndex = Math.min(currentIndex + 1, sections.length - 1);
            }
            smooth(sections[nextIndex]);
        }
        // обработчики для кнопок
        navUp.addEventListener("click", () => {
            if(navUp.classList.contains('not_found')) return;
            scrollToSection("up");
        });
        navDown.addEventListener("click", () => {
            if(navDown.classList.contains('not_found')) return;
            scrollToSection("down");
        });
        // обработчики для клавиш вверх и вниз
        document.addEventListener("keydown", (event) => {
            event.preventDefault();
            if (event.code === "ArrowUp") {
                scrollToSection("up");
            } else if (event.code === "ArrowDown") {
                scrollToSection("down");
            }
        });
        let addClass = () => {
            const up = sections[0].getBoundingClientRect().bottom >= 1;
            const down = sections[sections.length - 1].getBoundingClientRect().top <= 1;
            navUp.classList.toggle("not_found", up);
            navDown.classList.toggle("not_found", down);
        }
        addClass()
        window.addEventListener("scroll", addClass);

    </script>
</body>

</html>
Ответить с цитированием
  #17 (permalink)  
Старый 05.06.2023, 21:44
Профессор
Отправить личное сообщение для Сергей Ракипов Посмотреть профиль Найти все сообщения от Сергей Ракипов
 
Регистрация: 01.06.2010
Сообщений: 668

рони,
Просто одно слово ОГНИЩЕ!!! спасибо !!!
Ответить с цитированием
  #18 (permalink)  
Старый 14.09.2023, 11:17
Новичок на форуме
Отправить личное сообщение для playzoffs Посмотреть профиль Найти все сообщения от playzoffs
 
Регистрация: 14.09.2023
Сообщений: 1

Просто я понимаю что нет таких настроек как плавность в браузере krnl download
hdstreamz.uno

Последний раз редактировалось playzoffs, 23.11.2023 в 14:07.
Ответить с цитированием
Ответ



Опции темы Искать в теме
Искать в теме:

Расширенный поиск


Похожие темы
Тема Автор Раздел Ответов Последнее сообщение
Как обойти присвоение одинаковых id двум блокам? NeonMan jQuery 38 01.09.2018 02:17
Скрипт, чтобы текстовым блокам давался красный бекграуд каждому по очереди barakuda jQuery 7 13.04.2016 18:15
скроллинг по блокам ecSpl01t Элементы интерфейса 4 17.09.2014 11:47
скроллинг по блокам ecSpl01t jQuery 0 15.09.2014 21:04
AJAX навигация без якоря(Требуется помощ) Radik55rus AJAX и COMET 11 14.08.2014 10:34