//普通函数
function box() { //函数名是 box
return'Lee';
}
//匿名函数
function(){ //匿名函数,会报错
return'Lee';
}
//通过表达式自我执行
(functionbox() { //封装成表达式
alert('Lee');
})(); //()表示执行函数,并且传参
//把匿名函数赋值给变量
var box=function(){ //将匿名函数赋给变量
return'Lee';
};
alert(box()); //调用方式和函数调用相似
//函数里的匿名函数
function box() {
return function(){ //函数里的匿名函数,产生闭包
return'Lee';
}
}
alert(box()()); //调用匿名函数
var result = [];
function fn() {
for (var i = 0; i < 5; i++) {
result[i] = function() {
console.log(i);
}
}
}
fn();
result[0](); --->5
result[1](); --->5
result[2](); --->5
fn()函数调用完成后已经完成了所有遍历,但是此时由于是闭包,内部的i并没有销毁,于是调用result[0]可以取出i的值5
var result = [];
function fn() {
for (var i = 0; i < 5; i++) {
result[i] = (function(n) {
return function() {
console.log(n);
}
})(i);
}
}
fn();
result[0](); -->0
result[1](); -->1
result[2](); -->2
fn(自执行的匿名函数(匿名函数))
中间层的自执行匿名函数将自由变量i传入后保护了i不被外界改变,所以每次循环得到的 i 都被保护到中间层的自执行的匿名函数内了!
由于闭包里作用域返回的局部变量资源不会被立刻销毁回收,所以可能会占用更 多的内存。过度使用闭包会导致性能下降,建议在非常有必要的时候才使用闭包。