js闭包的理解

闭包,正常理解是,函数内部的函数,用来访问局部变量,不让这个变量污染外部环境的。

但很多人,没有真正理解闭包的实际特点,今天我仔细研究了下闭包。

先看下这段代码

function debounce(fn,delay){
    let timer = null //借助闭包
    var x = 1
    console.log(timer,'外层');
    return function() {
        if(timer){
            clearTimeout(timer) 
        }
        timer = setTimeout(fn,delay) // 简化写法
        console.log(timer,'内层');
    }
}

我们用闭包简单实现了一个防抖函数,我们在return function函数外层和内层做了输出,看是否调用debounce()都能触发。

做了一个按钮

<button>点击</button>
function show  () {
console.log('点击第' + ++n,'次');
}

设置了个点击事件

var btn = document.querySelector('button')
btn.onclick = debounce(show,1000) 

我们打开网页后,控制台就执行了变量的定义,和console.log

 在我们点击一次按钮后,先后隔一秒输出了内层和防抖的目标函数

 再点击一次,并没有输出外层,而是只执行内层

 综上,闭包我认为就是主要用来定义局部变量,并且,这个变量不会被重复定义,只会在声明,要被使用时才会执行,只用函数内部return的函数会被重复使用。

其实整个js也是一个闭包,我们所声明的也只能执行一次,而函数可以重复调用。

over。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值