javascript闭包的理解及应用场景

概要

  1. 闭包:一个函数内声明另一个函数
  2. 特点:闭包资源会一直存在,不会自动释放,必须手动释放,否则会一直占用内存
  3. 释放内存的方法:执行完之后,将最外层调用设置为null
  4. 优点:
    • 保护函数内的变量安全,防止变量被污染,实现封装
    • 缓存数据,在内存中维持一个变量
  5. 缺点:
    • 使用多了就会占用大量内存造成内存泄漏,要适当的使用
  6. 使用场景:模拟块级作用域/缓存数据,实现封装

示例

  • 防抖 利用了闭包的方式实现
  • 好处:将timer变量保存在内存中,只需要执行一次const d = debounce(),在以后需要的时候再调用d(),这样函数中的timer就不会是null,就是上次生成的值,一直保存在内存中保护了变量,就这样实现了封装。
export function debounce(fn, dealy) {
	let timer = null;
	return function() {
		if (timer) {
			clearTimeout(timer)
		}
		timer = setTimeout(fn, dealy)
	}
}

使用方法:
const d = debounce(()=>{
    console.log('回调')
},300);
// 假设在input输入的时候调用d(),这样就实现了防抖的功能
$('.input').on('input',()=>{
    d();
})
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

上网的虫不叫网虫

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值