js基础-作用域和闭包

作用域

什么是作用域?
每个代码块都会形成一个作用域,变量,对象,函数都只能在当前作用域和所有的下级作用域被使用
什么是自由变量?
在当前作用域没有被声明,但是却被使用了的变量。
js遇到自由变量就会往上级作用域一层一层找,直到找到为止,如果找不到就会报错xx is not defined

闭包

有两种情况:
1.函数作为返回值返回**

//函数作为返回值
function out(){
	let a = 1
	function in(){
		return ++a
	}
	return in
}
const fn = out()
let a = 2
console.log(fn()) //1

当out函数在函数外被调用并且返回的函数in被引用
由于执行函数out所创建的局部变量a通过引用in函数的变量可以被访问到(可达),所以不会被销毁,此时这个被引用的in函数实例就是一个闭包,为什么被称为闭包,因为他打破了作用域规则
2.函数作为参数被传递

//函数作为参数
function print(fnIn){
	let a = 2
	console.log(fnIn())
}
let a = 1
function fnOut(){
	return a
}
print(fnOut) //1

闭包的应用场景
场景一:防抖和节流

//防抖
function debounce(fn,delay){
   let timeout
    return function(){
        if(timeout){
            clearTimeout(timeout)
        }
        timeout = setTimeout(() => {
            fn(...arguments)
        },delay)
    }
}
//节流
function throttle(fn,delay){
    let flag = true
    return function(){
        if(flag){
            flag = false
            setTimeout(() => {
                fn(...arguments)
                flag = true
            },delay)
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值