码迷,mamicode.com
首页 > Web开发 > 详细

js的闭包的一个示例说明

时间:2015-03-20 12:50:28      阅读:152      评论:0      收藏:0      [点我收藏+]

标签:

js中 某个函数的内部函数在该函数执行结束后仍然可以访问这个函数中定义的变量,这称为闭包(Closure)
复制代码 代码如下:

function outside() 
{ 
var myVar = 1; 
return function (){ 
alert(myVar); 
} 
} 
var t = outside(); 
t(); 

js中 某个函数的内部函数在该函数执行结束后仍然可以访问这个函数中定义的变量,这称为闭包(Closure) 
下面例子是给三个锚anchor1,anchor2,anchor3添加onclick事件,可以预期的效果是点击锚点显示相应的锚点ID,实际上却都是显示"My id is anchor4", 这个就是闭包作用引起的逻辑上的bug,添加事件的函数执行完后i的值为4, 
复制代码 代码如下:

ADS.addEvent(window, ‘load‘, function(W3CEvent) {m 
for (var i=1 ; i<=3 ; i++ ) { 

var anchor = document.getElementById(‘anchor‘ + i); 

ADS.addEvent(anchor,‘click‘,function() { 
alert(‘My id is anchor‘ + i); 
}); 
} 
}); 

 

js的闭包的一个示例说明

标签:

原文地址:http://www.cnblogs.com/hellman/p/4353301.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!