js闭包经典问题的理解 迷南。 2022-10-19 15:59 156阅读 0赞 ### 文章目录 ### * JS闭包的作用 * 错误示例 * 引用和复制 * * 举例说明 * 作用域 * 闭包 -------------------- # JS闭包的作用 # > 本质上,闭包就是将函数内部和函数外部连接起来的一座桥梁。 闭包可以用在许多地方。 它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。2009年8月30日学习Javascript闭包(Closure) - 阮一峰的网络日志 # 错误示例 # <body> <p class="myP">test</p> <p class="myP">test2</p> <p class="myP">test3</p> </body> **目的:** 输出当前点击节点的序号 var nodes = document.getElementsByClassName('myP'); var add_the_handlers = function(nodes){ var i for(var i = 0; i < nodes.length; i++){ nodes[i].onclick = function(e){ console.log(i); } } } add_the_handlers(nodes); **输出结果:** 节点总数 / 最后一个节点的序号 **错误原因:** 内部函数在使用外部变量时使用引用的方式而不是复制 -------------------- # 引用和复制 # 在JS中,属于**引用数据类型**的有 **对象、数组、函数**,这些数据类型**传的是址**。 属于**复制数据类型**的有 **复制:数字、布尔**,这些数据类型**传的是值**。 传值的比较比较的是数值 而传址的比较比较的是引用,引用不同即使数值相同也不等 1 == 1; //true 1 === 1; //true [0] == [0]; //false [0][0] == [0][0]; //true [0][0] === [0][0]; //true [0].toString() == [0].toString(); //true ## 举例说明 ## var a = 1; var b = a; //赋的是a的复制值 b ++; alert(a); //"1" b的修改不影响a var a = [1]; var b = a; //赋的是a的引用 b[0] ++; alert(a); //"2" b的修改对a也有效 **函数的参数** 传值的传递:传给函数的是数值的一个复制,函数中对其的修改外部不可见 var a = 1; var b = 2; function change(a,b) { var c = a; a = b; //用新引用覆盖 b = c; alert(a); //"2" alert(b); //"1" } change(a,b); alert(a); //"1" alert(b); //"2" 传址的传递:传给函数的是数值的一个引用,函数中对其属性的修改外部可见,但用新引用覆盖其则在外部不可见 var a = [1, 2, 3]; var b = [5, 6]; function change(a,b) { a[0] = 4; //对其属性的修改外部可见 外部输出结果从1,2,3变为4,2,3 var c = a; a = b; //用新引用覆盖 外部输出结果不变 b = c; alert(a); //"5,6" alert(b); //"4,2,3" } change(a,b); alert(a); //"4,2,3" alert(b); //"5,6" 如果要使上述ab在函数外部互换,就需要通过**作用域**来实现。 -------------------- # 作用域 # var a = [1, 2, 3]; var b = [5, 6]; function change() { var c = a; a[0] = 4; a = b; b = c; }; change(); alert(a); //"5,6" alert(b); //"4,2,3" 因为js没有块级作用域,所以它在change里找不到变量a、b,所以会向上级寻找,操作的都是全局变量的引用。 -------------------- # 闭包 # 在搞明白了复制、引用和作用域的概念后,我们就可以去更好的理解闭包了,还是用上面的例子 <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title></title> </head> <body> <p class="myP">test</p> <p class="myP">test2</p> <p class="myP">test3</p> </body> <script> window.onload = function(){ var nodes = document.getElementsByClassName('myP'); // 通过立即执行函数每当i改变前,使内部函数获得外部变量i的复制并绑定事件。 // 示例1: 通过 匿名函数 立即执行来传递外部变量i var add_handlers = function (nodes) { var i; for (i = 0, l = nodes.length; i < l; i ++) { // 接收一个参数i // 该参数为数字类型,传进去后是数字的复制,而非引用 nodes[i].onclick = function (i) { // 返回函数给事件处理器,以实现点击后弹窗的操作 return function(){ // 此处的i值是传进来的i,属于函数的私有变量 alert(i); } }(i); // 通过(i)来使函数立即执行,同时通过(i)使其获得外部变量i的复制 } }; // 示例2:通过 辅助函数 来传递外部变量i var add_the_handlers = function(nodes){ var helper = function(i){ return function(){ alert(i); // 此处的i是函数形参的值,属于helper函数的私有变量 } } var i; for(i = 0; i < nodes.length; i++){ // 通过立即执行函数helper(i)来将外部变量i的值的复制传递给了helper nodes[i].onclick = helper(i) } } add_the_handlers(nodes); } </script> </html> 通过闭包,我们可以实现从内部函数拿到外部函数的变量。 [文章部分案例参考见此][Link 1] [Link 1]: https://www.cnblogs.com/onlywujun/articles/3438490.html
相关 经典js闭包题 下面是自己积累的几道经典JS闭包题 每一道都很有代表性,可能有的题解释的不到位,大家可以参考着结果先自己想一想,如果能够把这几道闭包题搞清楚,那么你在函数闭包上的成长一 - 日理万妓/ 2023年06月29日 02:20/ 0 赞/ 17 阅读
相关 js闭包经典问题的理解 文章目录 JS闭包的作用 错误示例 引用和复制 举例说明 作用域 闭包 -------------------- JS闭包 迷南。/ 2022年10月19日 15:59/ 0 赞/ 157 阅读
相关 理解JS闭包 闭包,是 Javascript 比较重要的一个概念,对于初学者来讲,闭包是一个特别抽象的概念,特别是ECMA规范给的定义,如果没有实战经验,很难从定义去理解它。因此,本文直 喜欢ヅ旅行/ 2022年06月16日 12:09/ 0 赞/ 243 阅读
相关 js闭包理解 转载自:[https://blog.csdn.net/baidu\_33295233/article/details/79127733][https_blog.csdn.net 曾经终败给现在/ 2022年05月18日 04:27/ 0 赞/ 203 阅读
相关 闭包经典问题 function test()\{ var arr = \[\]; for(var i = 0; i < 客官°小女子只卖身不卖艺/ 2022年03月16日 11:44/ 0 赞/ 215 阅读
相关 js 对 闭包的理解 这是关于 闭包和原型 的区别 以及 闭包的使用情景, mark一下 [https://segmentfault.com/q/1010000004067464][https_ 分手后的思念是犯贱/ 2022年01月23日 10:05/ 0 赞/ 243 阅读
相关 js经典闭包题 面试官:会闭包么? you:木问题!!! 面试官:那么做做下面的题吧? you:。。。(一脸懵逼中...) //经典闭包 functio 妖狐艹你老母/ 2021年09月18日 02:42/ 0 赞/ 348 阅读
相关 js闭包理解 1,js的链式作用域 \[html\] [view plain][] [copy][view plain] [![在CODE上查看代码片][CODE]][CODE_CODE 超、凢脫俗/ 2021年09月10日 11:00/ 0 赞/ 386 阅读
还没有评论,来说两句吧...