欢迎访问 生活随笔!

生活随笔

当前位置: 首页 >

js闭包绑定元素

发布时间:2025/3/14 26 豆豆
生活随笔 收集整理的这篇文章主要介绍了 js闭包绑定元素 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

闭包,官方对闭包的解释是:一个拥有许多变量和绑定了这些变量的环境的表达式(通常是一个函数),因而这些变量也是该表达式的一部分。闭包的特点:   1. 作为一个函数变量的一个引用,当函数返回时,其处于激活状态。   2. 一个闭包就是当一个函数返回时,一个没有释放资源的栈区。   

简单的说,Javascript允许使用内部函数---即函数定义和函数表达式位于另一个函数的函数体内。而且,这些内部函数可以访问它们所在的外部函数中声明的所有局部变量、参数和声明的其他内部函数。当其中一个这样的内部函数在包含它们的外部函数之外被调用时,就会形成闭包。

 

常见的陷阱: function createFunctions(){   var result = [];   for (var i=0; i < 10; i++){     result[i] = function(){       return i;     };   }   return result; } var funcs = createFunctions(); for (var i=0; i < funcs.length; i++){   console.log(funcs[i]()); } 开始以为输出的是0~9,其实界都是10个10,以为他是等for循环完之后才会做赋值,而不是每循环一次就
实例:
循环绑定元素:
方法一: <div class="button">1</div>
<div class="button">2</div>
<div class="button">3</div>
<div class="button">4</div>
<script type="text/javascript">
var div = document.getElementsByTagName('div')
for( var i=0;i<div.length;i++) {
(function (i) {
console.log(div[i].innerHTML);
div[i].οnclick=function () {
alert(div[i].innerHTML)
}
})(i);
}
</script>
这是一个简单的闭包,它会循环绑定<div>元素,点击哪个<div>,就会弹出它<div>所包含的内容

待续...


转载于:https://www.cnblogs.com/MyIsLu/p/6554875.html

总结

以上是生活随笔为你收集整理的js闭包绑定元素的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。