JavaScript 闭包的使用场景
一、闭包
由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,闭包就是能够读取其他函数内部变量的函数。所以,在本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。
比如下面的代码:
functionf1(){ varn=999; functionf2(){ console.log(n); } returnf2; } varresult=f1(); result();//999
函数f2就被包括在函数f1内部,这时f1内部的所有局部变量,对f2都是可见的。但是反过来就不行,f2内部的局部变量,对f1就是不可见的。
这就是Javascript语言特有的"链式作用域"结构(chainscope),子对象会一级一级地向上寻找所有父对象的变量。所以,父对象的所有变量,对子对象都是可见的,反之则不成立。
既然f2可以读取f1中的局部变量,那么只要把f2作为返回值,就可以在f1外部读取它的内部变量了。
二、闭包的使用场景
1.setTimeout
原生的setTimeout传递的第一个函数不能带参数,通过闭包可以实现传参效果。
functionf1(a){ functionf2(){ console.log(a); } returnf2; } varfun=f1(1); setTimeout(fun,1000);//一秒之后打印出1
2.回调
定义行为,然后把它关联到某个用户事件上(点击或者按键)。代码通常会作为一个回调(事件触发时调用的函数)绑定到事件。
比如下面这段代码:
测试 12 20 30 functionchangeSize(size){ returnfunction(){ document.body.style.fontSize=size+'px'; }; } varsize12=changeSize(12); varsize14=changeSize(20); varsize16=changeSize(30); document.getElementById('size-12').onclick=size12; document.getElementById('size-20').onclick=size14; document.getElementById('size-30').onclick=size16;