javascript中的作用域、闭包是一个不好理解的概念,需要慢慢领悟。现在把我自己学习作用域、闭包所理解的东西分享一下。
要领悟闭包必需理解javascript变量的作用域问题。
看下面代码1
var str="test"; //定义str if(true){ var str="hello"; //定义str } alert(str);
会打印输出什么:test 还是 hello?
你会看到hello
看下面代码2
var str="test"; //定义str function a(){ if(true){ var str="hello"; //定义str } } a(); alert(str);
会打印输出什么:test 还是 hello?
你会看到test
让我明白:代码1与代码2比较一下可以看到代码2多了一个function,在javascript中一直描述作用域“函数级”,在a()同定义了一个str,作用域就在a()函数内,与外面定义str没有关系。
我们在学习javascript的时候变量有:全局变量和局部变量
这里提到的全局变量与函数级作用域也有关系。
------------------------------------- ------------------------------------- -------------------------------------
看下面代码3
var str="test"; //定义str alert(str==window.str)
会打印输出什么:true还是false?
你会看到true
看下面代码4
function a(){ str="test"; } a(); alert(str==window.str)
会打印输出什么:true还是false?
你会看到true
让我明白:定义全局变量的两种方式:1.不定义在函数内,2.在fun中不加关键字var,所有的全局变量都是window对象的属性。
------------------------------------- ------------------------------------- -------------------------------------
看下面代码5
(function(){ var str="test"; if(true){ var str="hello"; } alert(str); alert(str==window.str); })()
会打印输出什么:test还是hello? true 还是false?
你会看到hello,false;
让我明白:代码5与代码1看上去很像,但本质已经变了,代码中已经包装了一个匿名函数,既然是函数,那么里面的变量都是函数级的了,使用var定义的str就是函数级的变量,作用范围只能在匿名函数中。而window现在根本没有str这个属性。你可以尝试使用alert(window.str),你会看到undefined,因为str根本不存在。
关于闭包要理解作用的基础上去理解闭包。
也许闭包的说法很多,但我个人觉得《精通javascript》的说法我能更好的理解:闭包意味着内层的函数可以引用存在于包围它的函数内的变量,即使外层函数的执行已经终止。从文字上去理解真是有些困难。
------------------------------------- ------------------------------------- -------------------------------------
看下面代码6
<button id="btnAdd">+</button>
var btnAdd = document.getElementById("btnAdd"); function addNum(){ var num=0; return function(){ alert(num++); } } btnAdd.onclick = addNum();
连续点击button会怎么样呢?
第一次点击弹出:0
第二次点击弹出:1
第三次点击弹出:2
第四次点击弹出:3
...
会延续下去。
为会呢?
让我明白:原来上面是一个闭包,内层函数是一个return 的匿名函数,这个匿名函数去访问包围它的addNum变量num。当在执行btnAdd.onclick = addNum();addNum()就已经终止了,当我们点击button的时候还在访问变量num,也就意味着点击button的时候只执行了这个匿名函数,外层函数没有执行。
------------------------------------- ------------------------------------- -------------------------------------
看下面代码7
<ul> <li><a href="">aa1</a></li> <li><a href="">aa2</a></li> <li><a href="">aa3</a></li> <li><a href="">aa4</a></li> </ul>
var aArg = document.getElementsByTagName("a"); for(var i=0;i<aArg.length;i++){ aArg[i].onclick = function () { alert(i); } }
以上代码会怎么样呢?不管你点击aa1还是aa2还是aa3还是aa4都会统一弹出:4,
是这为什么呢?
上面是一个闭包,但我们在点击的时候代码已经执行完成,代码执行完成后i的值是4 。所以一直会弹4。(闭包允许你引用父函数中的变量,但提供的值并非该变量创建时的值,而是父函数范围内的最终值)。
明白这一点所以我们必须创建一个作用域来保存每次for循环时i的值。
看下面代码8
var aArg = document.getElementsByTagName("a"); for (var i = 0; i < aArg.length; i++) { (function () { var index = i; aArg[i].onclick = function () { alert(index); } })() }
代码8中有一个立即执行函数,来保存i的值。
这样点aa1的时候,弹出0
这样点aa2的时候,弹出1
这样点aa3的时候,弹出2
这样点aa4的时候,弹出3
理解好作用域与闭包我们可以简化很多工作,javascript里面有很多细节的东西,学会javascript是简单的事情,但想学习好有很长的路要走。有兴趣的朋友加QQ:460666546
相关推荐
标题《JavaScript闭包的理解》涉及的知识点主要围绕JavaScript编程中的一个重要概念——闭包。闭包是一个高级且复杂的话题,它是JavaScript语言的核心特性之一,同时也是一大难点。要想熟练运用JavaScript,掌握闭包...
Javascript中有几个非常重要的语言特性——对象、原型继承、闭包。其中闭包 对于那些使用传统静态...本文将以例子入手来介绍Javascript闭包的语言特性,并结合一点 ECMAScript语言规范来使读者可以更深入的理解闭包。
### JavaScript闭包的理解 #### 一、闭包的定义与特点 闭包是JavaScript中一个非常重要的概念,它指的是一个函数能够访问并操作其外部作用域中的变量的能力。这一特性使得JavaScript具有了一些其他语言不具备的...
本文将以例子入手来介绍Javascript闭包的语言特性,并结合一点 ECMAscript语言规范来使读者可以更深入的理解闭包。闭包是Closure, 资源太大,传百度网盘了,链接在附件中,有需要的同学自取。
### JavaScript闭包完整解释 #### 一、闭包的基本概念 **闭包**是一个非常重要的JavaScript概念,它指的是一个函数能够记住并访问其外部作用域中的变量的能力,即使该函数在其外部作用域之外被调用也是如此。具体...
闭包是JavaScript编程中的一个重要概念,它涉及到函数、作用域、内存管理和变量持久化等多个方面...理解闭包对于编写高效、健壮的JavaScript代码至关重要。通过不断实践和深入学习,开发者可以更好地掌握这一核心概念。
深入理解javascript原型和闭包(01)——一切都是对象 深入理解javascript原型和闭包(02)——函数和对象的关系
本文结合 ECMA 262 规范详解了闭包的内部工作机制,让 JavaScript 编程人员对闭包的理解从“嵌套的函数”深入到“标识符解析、执行环境和作用域链”等等 JavaScript 对象背后的运行机制当中,真正领会到闭包的实质。
总之,JavaScript闭包是理解和掌握JavaScript高级特性的重要基础,它允许开发者创造出更为灵活和功能强大的代码结构。通过学习闭包的原理和应用,开发者可以更好地控制函数执行的上下文环境,以及更有效地管理变量的...
闭包是ECMAScript (JavaScript)最强大的特性之一,但用好闭包的前提是必须理解闭包。闭包的创建相对容易,人们甚至会在不经意间创建闭包,但这些无意创建的闭包却存在潜在的危害,尤其是在比较常见的浏览器环境下...
JavaScript 闭包是一种高级编程概念,它在JavaScript中扮演着至关重要的角色,特别是在函数式编程和模块化设计中。闭包本质上是函数和其能够访问...通过学习这些实例,你将能够更好地掌握JavaScript闭包这一核心概念。
详解JavaScript闭包问题 闭包是纯函数式编程语言的传统特性之一。通过将闭包视为核心语言构件的组成部分,JavaScript语言展示了其与函数式编程语言的紧密联系。由于能够简化复杂的操作,闭包在主流JavaScript库...
理解闭包的关键在于理解JavaScript的作用域规则。在实际应用中,闭包是JavaScript工程师必须掌握的概念。尽管闭包提供了强大的功能,但在某些情况下也可能会导致内存泄漏,特别是在旧版浏览器中的JavaScript引擎可能...
### JavaScript闭包详解 #### 一、闭包的定义与概念 闭包是JavaScript中一个非常重要的概念,它涉及到函数作用域以及变量的作用域链。简单来说,闭包就是一个能够访问其外部作用域中变量的函数。具体而言,当一个...
### JavaScript闭包技术详解 #### 一、闭包的基本概念 **闭包**是JavaScript中一个重要的概念,它涉及到函数的执行环境、作用域链等关键要素。简单来说,闭包是一个函数及其相关的引用环境的组合。具体而言,当一...
### JavaScript闭包高级教程 #### 简介 在JavaScript编程中,“闭包”是一个非常重要的概念,尤其对于希望深入理解和高效使用JavaScript的开发者来说。简单地说,闭包是一种能够记住并访问其创建时周围环境的函数...
### JavaScript闭包的理解 在JavaScript中,闭包(Closure)是一种非常重要的概念,它涉及到函数作用域、变量生命周期以及函数内部对外部作用域的访问等多个方面。本文将基于提供的文件内容,深入探讨JavaScript...
总之,深入理解JavaScript闭包对于编写高效、可维护的代码至关重要。掌握闭包不仅有助于解决实际问题,还能提高编程技巧和对JavaScript语言机制的理解。在日常开发中,无论是用于实现模块化、数据封装,还是处理异步...