会员可以在此提问,百战程序员老师有问必答
对大家有帮助的问答会被标记为“推荐”
看完课程过来浏览一下别人提的问题,会帮你学得更全面
截止目前,同学们一共提了 132365个问题


mvcdemo2.zip

apache-tomcat-8.0.38.zip

老师 我的图片出不来 upload里也没有图片 我找了找那个错误也不会改

image.png

JAVA 全系列/第六阶段:项目管理与SSM框架/SpringMVC旧 37906楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/容器(旧) 37907楼
WEB前端全系列/第五阶段:前后端交互/PHP、数据库编程与设计 37908楼
Python 全系列/第二阶段:Python 深入与提高/模块 37911楼
Python 全系列/第一阶段:Python入门/序列 37912楼

<!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>
        body {
            height: 4000px;
        }
    </style>
</head>

<body>
    <button>测试闭包</button>
    <!-- 防抖 -->
    <script>
        var btn = document.getElementsByTagName("button")[0];

        function showScrollTop() {
            var scrollTop = document.documentElement.scrollTop;
            console.log(scrollTop);
        }

        function debounce(fn, delay) {
            var timer = null;
            return function() {
                if (timer) {
                    clearTimeout(timer);
                }
                timer = setTimeout(fn, delay);
            }
        }
        result = debounce(showScrollTop, 200);
        window.addEventListener("scroll", result)
            /*  result = print();
             btn.addEventListener('click', result)

             function print() {
                 console.log('我不是闭包');
                 return function() {
                     console.log('我是闭包');
                 }
             } */
    </script>
</body>

</html>

我现在理解一点儿了。它只做一次不是什么事件机制,函数体只做一次的原因。它就是因为闭包才只执行var timer=null 一次的。debounce()说明是这个参数是debounce()函数返回值,而它的返回值就是重复做的闭包的函数。我先是用注释的print()函数试一试,发现即使不触发事件,“我不是闭包”也会打印出来。它可以单独拿出来,就像之前写闭包一样。它执行一次就是因为需要取得返回值函数。而事件绑定的函数是返回值函数,所以能不停执行。

WEB前端全系列/第二阶段:JavaScript编程模块/浏览器模型(BOM) 37913楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/手写服务器项目(旧) 37914楼
Python 全系列/第一阶段:Python入门/控制语句 37915楼
JAVA 全系列/第九阶段:权限控制与安全认证/Shiro(旧) 37916楼
JAVA 全系列/第十七阶段:微信与支付宝在线支付/微信支付 37918楼
JAVA 全系列/第二阶段:JAVA 基础深化和提高/智能电话本项目实战 37920楼

课程分类

百战程序员微信公众号

百战程序员微信小程序

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