会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 133808个问题
Python 全系列/第十六阶段:Python 爬虫开发/scrapy框架使用 15871楼
Python 全系列/第三十一阶段:Spark体系之分布式计算(扩展)/RDD 15872楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/常用类 15873楼
JAVA 全系列/第一阶段:AI驱动的JAVA编程/JAVA入门和背景知识 15874楼
Python 全系列/第十一阶段:Flask百战电商后台项目/Flask百战电商后台项目 15875楼
Python 全系列/第八阶段:轻量级Web开发利器-Flask框架/Flask视图高级 15879楼
Python 全系列/第九阶段:企业级Web框架/FastAPI:现代化API框架 15881楼
Python 全系列/第十九阶段:数据分析-数据可视化/matplotlib 15882楼
JAVA 全系列/(旧的隐藏)第七阶段:JAVA 高级技术/MongoDB 15883楼

17:03分讲解的这个方法好像有问题:

image.png

image.png

<!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>浏览器页面滚动防抖</title>

    <style>

        #container {

            height: 5000px;

            background-color: #f0f0f0;

        }

    </style>

</head>


<body>

    <div id="container">


    </div>



    <script>

        // 防抖函数

        function deBounce(func, wait) {

            //使用局部变量保存timer (不污染全局变量)

            var timer = null;

            return function () {

                if (timer) {

                    clearTimeout(timer);

                }

                timer = setTimeout(func, wait);

            }

        }


        // 获取页面滚动高度

        function getScrollTop() {

            //获取滚动元素

            let scrollTop = document.documentElement.scrollTop;

            console.log(scrollTop);

        }




        //错误写法 滚动事件触发一次,就生成一个新的防抖函数

        window.onscroll = function () {

            var result= deBounce(getScrollTop, 1000)();

        };


        //正确写法 只在绑定事件时创建一次防抖函数

        // 滚动事件触发时,调用的始终是同一个防抖函数实例

        // window.onscroll = deBounce(getScrollTop, 1000);



    </script>

</body>


</html>


WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 15884楼
Python 全系列/第一阶段:AI驱动的Python编程/控制语句 15885楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

©2014-2025百战汇智(北京)科技有限公司 All Rights Reserved 北京亦庄经济开发区科创十四街 赛蒂国际工业园
网站维护:百战汇智(北京)科技有限公司
京公网安备 11011402011233号    京ICP备18060230号-3    营业执照    经营许可证:京B2-20212637