javascript自启动函数的问题探讨
时间:2024-04-30 08:55:57
话不多说了。
先来看两段代码:
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闭包的知识。
以上代码,想了很久,记录下来,以防止忘记。
标签:自启动,函数
![](/images/zang.png)
![](/images/jiucuo.png)
猜你喜欢
VS Code配置Go语言开发环境的详细教程
2024-05-11 09:08:31
![](https://img.aspxhome.com/file/2023/0/127030_0s.jpg)
Python存取XML的常见方法实例分析
2023-07-30 07:36:38
使用python修改文件并立即写回到原始位置操作(inplace读写)
2021-02-04 11:22:31
![](https://img.aspxhome.com/file/2023/2/127762_0s.jpg)
Kettle下载安装pdi-ce-7.1.0.0-12教程
2023-11-27 05:38:36
![](https://img.aspxhome.com/file/2023/6/114706_0s.jpg)
浅析PyTorch中nn.Module的使用
2021-10-29 14:04:53
python使用ctypes调用扩展模块的实例方法
2021-11-01 22:22:58
![](https://img.aspxhome.com/file/2023/2/82542_0s.png)
JavaScript获取echart曲线上任意点位的值详解
2024-05-02 16:57:52
![](https://img.aspxhome.com/file/2023/8/130148_0s.png)
Python将xml和xsl转换为html的方法
2022-04-02 14:24:32
30个出色的分页设计
2009-05-12 17:49:00
![](https://img.aspxhome.com/file/UploadPic/20095/12/220023a63-30s.jpg)
磁盘缓存专题之一 缓存命中和缓存未命中&缓存与缓冲间的差异
2012-10-07 11:02:46
Python3 中sorted() 函数的用法
2021-09-29 04:00:55
![](https://img.aspxhome.com/file/2023/2/121522_0s.png)
Python操作mongodb数据库进行模糊查询操作示例
2024-01-29 03:40:45
asp如何处理超时事件?
2009-11-14 20:41:00
CSS Shadow Practice
2009-04-01 18:37:00
matplotlib 曲线图 和 折线图 plt.plot()实例
2022-06-19 13:55:06
![](https://img.aspxhome.com/file/2023/4/99564_0s.jpg)
python实现简单的超市商品销售管理系统
2021-08-24 00:07:32
![](https://img.aspxhome.com/file/2023/1/134811_0s.jpg)
PHP Static延迟静态绑定用法分析
2024-06-05 15:42:42
python实现逐个读取txt字符并修改
2021-03-11 21:25:53
![](https://img.aspxhome.com/file/2023/4/115014_0s.jpg)
Python进行文件处理的示例详解
2021-12-08 10:51:04
vue项目中将element-ui table表格写成组件的实现代码
2024-05-28 15:55:31
![](https://img.aspxhome.com/file/2023/8/123118_0s.png)