匿名函数和闭包

匿名函数·

匿名函数就是没有名字的函数

实例

(function(){

alert("");

})();

!(function(){

alert("");

}();

闭包·

有权访问另一个函数作用域中的变量

创建闭包的常见方式,就是在一个函数内部创建另一个函数,通过另一个函数访问这个函数的局部变量

function box(){

var age= 100;

return function(){

return age;

};

}

alert(box()());

使用闭包有一个优点,也是它的缺点:就是可以把局部变量驻留在内存中。可以规避使用全局变量。(全局变量污染导致应用程序不可预测性,每个模块都可以调用必将引来灾难,所以推荐使用私有的,封装的局部变量)。



function box(){·

var age =100;

return function(){

age++;

return age;

};

}

var b = box();

alert(b())

alert(b())




例子1.

function box(){

var myarr = [];

for(var i = 0;i < 5;i++){

myarr[i] = function(){

return i;}

}

return myarr;}

// console.log(box());

alert(box());---------》[function(){},function(){},function(){},function(){},function(){},function(){},] 匿名函数数组

var b = box();//数组  //for 已经执行完毕  i = 5

for(var j = 0;j < b.length;j++){

alert(b[j]());

}-------------------》5 5 5 5 5



例子2.

function box(){

var myarr = [];

for(var i = 0;i < 5;i++){

// myarr[i] = i;

// myarr[i] = (function(){

// return i;

// })();

myarr[i] = (function(num){

return num;

})(i);

}

return myarr;

}

alert(box())---------------0 1 2 3 4





由于闭包里作用域返回的局部变量资源不会被立刻销毁回收,所以可能会占用更多的内存,过渡使用闭包会导致性能下降,建议在非常有必要的时候才使用闭包。·

使用完之后给它加null,解除引用

b=null

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 相信很多前端小伙伴在工作和学习中,都会或多或少的接触和了解到匿名函数和闭包。被这俩知识点所困扰,也去网上搜索...
    就那ck阅读 9,165评论 7 21
  • 之前在学编译原理的时候接触过闭包这个概念,就是一组数据中所有数据的任意组合为闭包,然而突然看到与匿名函数放在一起了...
    小m_up阅读 369评论 1 1
  • 工厂模式类似于现实生活中的工厂可以产生大量相似的商品,去做同样的事情,实现同样的效果;这时候需要使用工厂模式。简单...
    舟渔行舟阅读 7,963评论 2 17
  • 匿名函数 匿名函数(Anonymous function),也叫闭包函数(closures),允许临时创建一个没有...
    Jeffrey陈阅读 290评论 0 0
  • 第一章: JS简介 从当初简单的语言,变成了现在能够处理复杂计算和交互,拥有闭包、匿名函数, 甚至元编程等...
    LaBaby_阅读 1,714评论 0 6