美文网首页程序员让前端飞
web前端学习:深入理解JS闭包

web前端学习:深入理解JS闭包

作者: 560b7bb7b879 | 来源:发表于2018-07-24 21:05 被阅读18次

第一部分:初遇闭包

http://www.runoob.com/js/js-function-closures.html

什么是闭包?闭包有什么作用?这是我遇到闭包时的第一反应。

闭包在JavaScript高级程序设计(第3版)中是这样描述:闭包是指有权访问另一个函数作用域中的变量的函数。

那么闭包的作用也就很明显了。

1. 可以在函数的外部访问到函数内部的局部变量。

2. 让这些变量始终保存在内存中,不会随着函数的结束而自动销毁。

在上面的代码中,闭包指的就是function () {return counter += 1;}这个函数。首先解释一下这段代码,在变量add被赋值之前,第一个function执行了一次(执行且仅会执行一次),因为这是一个函数表达式声明方式并且声明后加上了(),所以会自动执行一次。执行后add被赋值(匿名函数)了,add= function () {return counter += 1;}。然后每次调用add()函数时,返回的都是这个函数,因为这个函数在第一个函数的内部,所以即使第一个函数执行完了,第二个函数依然能访问counter(JS设计的作用域链,当前作用域能访问上级的作用域)。

闭包是可以在另一个函数的外部访问到其作用域中的变量的函数。而被访问的变量可以和函数一同存在。即使另一个函数已经运行结束,导致创建变量的环境销毁,也依然会存在,直到访问变量的那个函数被销毁。当然,如果仅仅是做一个简单的计数器,大可不用这样麻烦。下面这简短的代码就能轻松实现。

var a = 0;

function myFunction(){

a++;

    document.getElementById("demo").innerHTML = a;

}

第二部分:牛客翻船

https://www.nowcoder.com/questionTerminal/da4115e308c948169a9a73e50d09a3e7

下面是这个题目的解答:

每个li标签的onclick事件执行时,本身onclick绑定的function的作用域中没有变量i,i为undefined,则解析引擎会寻找父级作用域,发现父级作用域中有i,且for循环绑定事件结束后,i已经赋值为4,所以每个li标签的onclick事件执行时,alert的都是父作用域中的i,也就是4。这是作用域的问题。

闭包只能取得包含函数中任何变量的最后一个值。因为别忘了闭包所保存的是整个变量对象,而不是某个特殊的变量。

这是在循环体中创建闭包的常见错误。https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Closures(一定要看这篇)

这里面给onclick赋值的是闭包。很多人会问为什么是闭包?之前闭包不是函数A里的函数B吗?函数B用来访问函数A的变量,称函数B是闭包,题目中只有一个函数为什么也是闭包。其实,用两个函数形成闭包只是一般形式。闭包真正的含义是,如果一个函数访问了此函数的父级及父级以上的作用域变量,就可以称这个函数是一个闭包。

    var a = 1;

    (function test (){

alert(a);

})()

所以上面的function都可以称之为闭包(匿名闭包函数)。

这里还是作用域的问题,那么我们把每次的i都保存到一个变量中,匿名闭包就可以实现想要的效果。

这样就使用了闭包,这里面的闭包指的是function() {alert(num);};第二个function里面弹出的num是第一个function的参数,通过(i)执行了这里面的第一个函数,同时i的值被保存到num中。每个点击事件中都有一个局部变量num,num保存的是相应的i值。

第三部分:let的横空出世

上面的牛客题目只需要将for(var i=0;ihttps://mp.csdn.net/postedit/81065540

let的到来,让令人诟病的JS获得了一丝生机,也补上了JS没有块级作用域的短板。ECMAScript6还有很多新特性,笔者也在不断学习中。

第四部分:闭包的应用

函数工厂和闭包模拟私有方法

https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Closures(这篇讲得很好,希望大家读透)

感谢阅读

喜欢看小编文章的点个订阅或者喜欢!小编每天都会跟大家分享文章,也会给大家提供web前端学习资料。

相关文章

  • web前端学习:深入理解JS闭包

    第一部分:初遇闭包 http://www.runoob.com/js/js-function-closures.h...

  • 好程序员web前端培训分享web前端面试题JS篇之闭包

    好程序员web前端培训分享web前端面试题JS篇之闭包,JS中关于闭包的相关知识。如果你想参加web前面工作,那么...

  • 我从来不理解JavaScript闭包,直到有人这样向我解释它..

    摘要: 理解JS闭包。 原文:我从来不理解JavaScript闭包,直到有人这样向我解释它... 作者:前端小智 ...

  • 探索奥秘~闭包

    在我学习初期我对闭包的理解也不是很深,最近在学习了js更深入的知识后,对闭包有了更加深入的了解,下面我就跟大家详细...

  • JavaScript深入理解-闭包(Closure)

    推荐文章:学习Javascript闭包(Closure)- 阮一峰javascript深入理解-从作用域链理解闭包...

  • js深入理解js闭包

    一、变量的作用域 要理解闭包,首先必须理解Javascript特殊的变量作用域。 变量的作用域无非就是两种:全局变...

  • 深入理解js闭包

    深入理解js闭包 1.闭包的含义 1.1 闭包:有权在一个函数内部可以访问另一个函数作用域并且将此函数返回 2.想...

  • 深入理解js闭包

    一、变量的作用域要理解闭包,首先必须理解Javascript特殊的变量作用域。变量的作用域无非就是两种:全局变量和...

  • 深入理解js闭包

    一、概念定义在函数内部的函数,通俗理解就是能够读取其他函数内部变量的函数。二、用途闭包的用途:其一就是读取函数内部...

  • 深入理解js闭包

    什么是闭包 MDN的解释:闭包是函数和声明该函数的词法环境的组合。 简单讲,闭包就是指有权访问另一个函数作用域中的...

网友评论

    本文标题:web前端学习:深入理解JS闭包

    本文链接:https://www.haomeiwen.com/subject/afoymftx.html