JavaScript闭包的小问题
怎么说,闭包大体也就是作用域的问题。
闭包的一个用途是用于模块化,保护函数体内的私有变量,如:
var foo = function(){
var _num = 1;
var sayHello = function(){
console.log('hello');
};
var getNum = function(){
return _num;
};
return {
getNum : getNum ,
sayHello : sayHello
}
}
var num = foo().getNum();
console.log(num); //1
foo().sayHello(); //hello
模块化的东西不多说,下面说之前一直不解的问题:
var $div = $("div");
for(var i = 0; i < $div.length;i++){ //length = 4
$div[i].onclick = function(){
console.log(i); // 4 4 4 4
}
}
原因在于log的参数i为形参,只有在onclick事件触发时,才将i赋值。
简单修改,通过立即执行函数即可将i进行绑定:
var $div = $("div");
for(var i = 0; i < $div.length;i++){ //length = 4
$div[i].onclick = (function(i){
console.log(i); // 1 2 3 4
}(i));
}