手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >javascript自启动函数的问题探讨
javascript自启动函数的问题探讨
摘要:话不多说了。先来看两段代码:复制代码代码如下:varelems=document.getElementsByTagName('a');for...

话不多说了。

先来看两段代码:

复制代码 代码如下:

var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; i++) {

alert(i);

elems[i].addEventListener('click', function (e) {

e.preventDefault();

alert('I am link #' + i);

}, 'false');

}

再看一面一段:

复制代码 代码如下:

var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; i++) {

(function(index){

elems[i].addEventListener('click', function (e) {

e.preventDefault();

alert('I am link #' + index);

}, 'false');

})(i);

}

HTML 代码如下:

复制代码 代码如下:

<body>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

<a href = "#">a</a>

</body>

你可以想像下,前后两段 script代码的效果。

如果你能看出来效果的区别,那么恭喜你。至少我思考了很久,才明白里面的玄妙。

是的。你没有看错,这里的第一段代码,无论你点击哪一个链接,输出的都是 I am link # 8.

第二段代码,才是你真正想要的结果,那么为什么呢。

看下面的代码:

复制代码 代码如下:

var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; i++) {

alert(i);

elems[i].addEventListener('click', function (e) {

e.preventDefault();

alert('I am link #' + i);

//注意这里的回调函数只有的触发的时候才会启动

//一样,这里的i的值也一样在循环结束的时候也变化了

}, 'false');

//原因在于

//这里的elems[i] 虽然是引用的元素

//但是回调函数中的i 已经在循环结束后

//变成了8(如果 elems 的长度是 8 的话)

}

复制代码 代码如下:

var elems = document.getElementsByTagName('a');

for (var i = 0; i < elems.length; i++) {

(function(index){

elems[i].addEventListener('click', function (e) {

e.preventDefault();

alert('I am link #' + index);

}, 'false');

})(i);

//而这里的则不一样

//虽然循环结束后i 的值变成了8

//但是在封装在闭包内的index 确实一直被locked 住的

//一直保存在内存中。

//准确的说 应该是整个函数都lock在内存中.

}

这里可能需要一些javascript闭包的知识。

以上代码,想了很久,记录下来,以防止忘记。

【javascript自启动函数的问题探讨】相关文章:

javascript操作ul中li的方法

JavaScript中exec函数用法实例分析

javascript动态创建表格及添加数据实例详解

Javascript 不能释放内存.

javascript先序遍历DOM树的方法

javascript鼠标滑动评分控件完整

多个iframe自动调整大小的问题

javascript实现动态改变层大小的方法

javascript实现链接单选效果

javascript带回调函数的异步脚本载入方法实例分析

精品推荐
分类导航