js闭包和防抖节流

1.闭包和它的优缺点

闭包就是能够读取其他函数内部变量的函数。在本质上,它是连接函数外部和内部的桥梁,可以重用一个变量,闭包形成的三大条件:

  1. 外层函数定义包裹内层函数
  2. 内层函数访问外层函数的变量
  3. 把内层函数当作返回值提供给外部访问

优点:第一,可以重复使用变量;第二,不污染全局变量
缺点:因为外部引用不被释放,无法被垃圾回收站回收,会长期占用内存,比一般函数更加消耗内存
示例:

//1.定义外部函数
function testClosure() {
    let num = 0;
    //3.返回内部函数
    return () => {
        //2.在内层函数访问外层函数
        console.log(num++)
    }
}

const num = testClosure()
num()//0
num()//1
num()//2

2.利用闭包实现防抖和节流

防抖和节流都是控制函数的都是降低程序执行频率的方法,但是防抖和节流有着本质的差别,防抖是指事件函数在一定时间连续触发只执行最后一次,节流是指同一单位时间内只执行一次

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <title>Document</title>
    <script>
        window.onload = function() {
            //获取两个按钮
            const debounceBtn = document.querySelector("#debounce")
            const thorttleBtn = document.querySelector("#thorttle")
            
            //防抖
            function Debounce(fn, delay) {
                let timer = null
                //定义内部函数
                const debounce = function() {
                    //形成闭包,timer变量不被释放,如果timer不为空则清除延时执行
                    if(timer) clearTimeout(timer)
                    //最后一次触发执行
                    timer = setTimeout(() => {
                        fn()
                    }, delay) 
                }

                return debounce
            }

            debounceBtn.onclick = Debounce(() => {console.log("Debounce")}, 1000)

            //节流
            function Thorttle(fn, delay) {
                let timer = null
                //定义内部函数
                const thorttle = function() {
                    //如果有延时任务则不在重新触发
                    if(!timer) {
                        timer = setTimeout(() => {
                            fn()
                            //delay时间后把timer设置为null
                            timer = null
                        }, delay)
                    }
                }

                return thorttle
            }

            thorttleBtn.onclick = Thorttle(() => {console.log("Thorttle")}, 1000)            
        }
    </script>
</head>
<body>
   <button id="debounce">防抖</button>
   <button id="thorttle">节流</button>
</body>
</html>
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值