アニメーショントップストーリー

目的関数

ここに画像を挿入説明

  • ボックスをクリックした後、徐々にトップに戻るのではなく、すぐに達します

コードの実装

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        body {
            height: 2000px;
        }

        header {
            height: 100px;
            background-color: skyblue;
        }

        div {
            position: fixed;
            top: 150px;
            left: 50%;
            width: 200px;
            height: 200px;
            transform: translateX(-50%);
            background-color: tomato;
            line-height: 200px;
            text-align: center;
            font-size: 20px;
            color: #ffffff;
            cursor: pointer;
        }
    </style>
</head>

<body>
    <header>我是顶部</header>
    <div>返回顶部</div>
    <script>
        var div = document.querySelector('div')
        div.addEventListener('click', function () {
            // 整个窗口滚动,对象是window
            animate(window,0)
        })

        // 改写原先封装的动画函数
        function animate(obj, target, callback) {
            clearInterval(obj.timer)
            obj.timer = setInterval(function () {
                // pageYOffset获取被卷去的头部
                if (obj.pageYOffset == target) {
                    clearInterval(obj.timer)
                    callback && callback()
                }
                var step = (target - obj.pageYOffset) / 10
                step = step < 0 ? Math.floor(step) : Math.ceil(step)
                // window.scroll(x,y)方法让元素滚动到指定位置
                // 现在要修改的是第二个参数值
                window.scroll(0,obj.pageYOffset + step ) 
            }, 15)
        }
    </script>
</body>

</html>
公開された135元の記事 ウォンの賞賛0 ビュー3082

おすすめ

転載: blog.csdn.net/qq_35764106/article/details/105255298