在上一篇中说到了作用域,简单介绍了一下块级作用域,在这里我们来详细介绍一下。 众所周知,在js中函数作用域是常见的单元作用域,也是现行的大多数js中最普遍的设计方案。...但其他类型的作用域单元也是存在的,并且通过使用其他类型的作用域单元甚至可以实现维护起来更加优秀、简洁的代码。这就是我们现在要说的块级作用域。...那么都有什么可以形成块级作用域呢,下面我们来看一下 try/catch 这个东西相信很多人也都用过,但是我们大部分时间写代码都是在try块中写的,不要认为try中写的代码就是块级作用域,其实里面声明的变量也会被声明为全局变量...总结 块级作用域非常有用的一点和闭包及回收内存垃圾的回收机制相关。...提供了块级作用域,但是我们应该合理的在代码中使用,结合不同场景使用不同的作用域,创造可读、可维护的优良代码。
什么是块级作用域 ES6 中新增了块级作用域。块作用域由 { } 包括,if 语句和 for 语句里面的 { } 也属于块作用域。...块级作用域与函数声明 ES5 规定,函数只能在顶层作用域和函数作用域之中声明,不能在块级作用域声明。...但是,浏览器没有遵守这个规定,为了兼容以前的旧代码,还是支持在块级作用域之中声明函数,因此上面两种情况实际都能运行,不会报错。 ES6 引入了块级作用域,明确允许在块级作用域之中声明函数。...因为块级作用域内声明的函数类似于let,对作用域之外没有影响。但是,如果你真的在 ES6 浏览器中运行一下上面的代码,是会报错的,这是为什么呢?...如果没有大括号,JavaScript 引擎就认为不存在块级作用域。
1.前言 作用域是任何一门编程语言中的重中之重,因为它控制着变量与参数的可见性与生命周期。很惭愧,我今天才深入理解JS的作用域..我不配做一个程序员.....开玩笑,什么时候理解都不晚,重要的是理解了以后能不能深深地扎在记忆里,不能,那就写下来 2.块级作用域 在一个代码块(括在一对花括号中的一组语句)中定义的所有变量在代码块的外部是不可见的。...ES6中新增的概念,在ES5中是没有的,ES5中没有? 没有的时候我们代码也写的好好的,现在新增的概念,我不用不行吗? 来,拋一个典型的问题出来,你就明白块级作用域出现的重要性了。...在ES5时代,还没有块级作用域这个概念,但是当时也有一种解决方法,那就是.. .. .. .. .....、以及块级作用域出现的意义,方便更好的记住。
模仿块级作用域 var somefunction=function(){ ///这里是块级作用域 } somefunction(); 在这里定义了一个函数,然后立即调用。不会报错。...然而,下面的代码: function(){ //这里是块级作用域 }(); //出错 这段代码会导致语法错误,因为javascript将function关键字当做一个函数声明的开始,而函数声明后不能跟圆括号...将函数声明转为函数表达式,像下面给它加上一对圆括号就可以了: (function(){ //这里是块级作用域 })(); (function(){ var now = new Date(); if(now.getMonth...这种做法减少闭包占用内存的问题,因为没有指向匿名函数的引用。执行完毕,立即销毁作用域链。...MyObject.prototype.piblicMethod = function (){ privateVariable++; return privateFunction(); } })(); 这个模式在定构造函数时并没有使用函数声明
块级作用域,let,const。(1.js) 1. let 1. let 声明的全局变量不是全局对象window的属性 2....同一作用域中用let定义变量不允许重复声明 3. let声明的变量不存在变量提升 4. let声明的变量具有暂时性死区 5. let 声明的变量拥有块级作用域 2. const
说到这里我们需要理解两个概念:块级作用域与函数作用域。 函数作用域 这个应该好理解,函数作用域就是说定义在函数中的参数和变量在函数外部是不可见的。 大多数类C语言都拥有块级作用域,JS却没有。...可以看到,C语言拥有块级作用域,因为j是在if的语句块中定义的,因此,它在块外是无法访问的。...块级作用域 ---- 任何一对花括号中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。...也就是说,JS并不支持块级作用域,它只支持函数作用域,而且在一个函数中的任何位置定义的变量在该函数中的任何地方都是可见的。 那么我们该如何使JS拥有块级作用域呢?...是否还记得,在一个函数中定义的变量,当这个函数调用完后,变量会被销毁,我们是否可以用这个特性来模拟出JS的块级作用域呢?
作用域 作用域永远都是任何一门编程语言中的重中之重,因为它控制着变量与参数的可见性与生命周期。说到这里我们需要理解两个概念:块级作用域与函数作用域。...函数作用域 这个应该好理解,函数作用域就是说定义在函数中的参数和变量在函数外部是不可见的。 大多数类C语言都拥有块级作用域,JS却没有。...块级作用域 任何一对花括号中的语句集都属于一个块,在这之中定义的所有变量在代码块外都是不可见的,我们称之为块级作用域。...也就是说,JS并不支持块级作用域,它只支持函数作用域,而且在一个函数中的任何位置定义的变量在该函数中的任何地方都是可见的。 那么我们该如何使JS拥有块级作用域呢?...是否还记得,在一个函数中定义的变量,当这个函数调用完后,变量会被销毁,我们是否可以用这个特性来模拟出JS的块级作用域呢?
简介:在JavaScript中没有块级作用域的概念。这意味这在块语句中定义的变量,实际上在包含函数中而非语句中创建的。...+){ break; } var i; alert(i); } outputNumbers(3); //输出:0 而JavaScript中的匿名函数可以用来模仿块级作用域并避免这个问题...用作块级作用域(通常成为私有作用域)的匿名函数语法如下所示: (function () { })()
第2章 块级作用域 2.1 块级作用域 JS中作用域有:全局作用域、函数作用域。 ES6中新增了块级作用域。 块作用域由 { } 包括,if语句和for语句里面的{ }就属于块作用域。...(不包括函数) //注意 块级作用域中,使用var声明的变量是全局变量 { var a = 1; console.log(a);//1 } console.log(a);//1 if(true){...var b = 2; console.log(b);//2 } console.log(b);//2 2.2、let关键字声明块级变量 ES6中增加了let关键字声明变量,声明的变量只在当前代码块中生效...(块级作用域)。...直接报错 预解析错误 { let a = 1; console.log(a); let a = 2; console.log(a); } 2.3、let变量没有变量提升
在 ES5 及之前版本,JavaScript 只拥有函数作用域,没有块作用域(with 和 try...catch 除外)。在 ES6 中,JS 引入了块作用域,{ } 内是单独的一个作用域。...采用 let 或者 const 声明的变量会挟持所在块的作用域,也就是说,这声明关键字会将变量绑定到所在的任意作用域中(通常是 {...} 内部)。 今天,我们就来深入研究一下函数作用域和块作用域。...在开发和修改代码的过程中,如果没有密切关注哪些代码块作用域中有绑定的变量,并且习惯性的移动这些块或者将其包含到其他块中,就会导致代码混乱。...使用块作用域可以解决这个问题,可以让引擎清楚的知道没有必要继续保存这个 bigData 。...总结 函数是 JavaScript 中最常见的作用域单元。块作用域指的是变量和函数不仅可以属于所处的函数作用域,也可以属于某个代码块。
面试官必问系列:深入理解JavaScript块和函数作用域 • 在 JavaScript 中,究竟是什么会生成一个新的作用域,只有函数才会生成新的作用域吗?...= 10; if (foo) { var bar = 3; // ... } if (baz > bar) { console.log( baz ); } • 但是在使用块级作用域的变量时需要注意以下变化...console.log( baz ); } } 3.4.4 const • ES6 还引入了 const, 同样可用来创建块级作用域,但其值是固定的(常量), 不可修改。...函数时 JavaScript 中最常见的作用域单元。 2. 块作用域值的是变量和函数布局可以属于所处的作用域,也可以属于某个代码块(通常指 {...} 内部) 3....从 ES3 开始, try/catch 结构在 catch 分句中具有块作用域。 4. 从 ES6 引入了 let,const 关键字来创建块级作用域。
在js中我们应该尽量避免使用全局变量和全局函数,以防止发生命名冲突,那么要如何避免呢?js中有一个闭包的概念,现在我们使用闭包中块级作用域来讲解,这也是闭包中最重要的概念。...js本身是不支持像C/C#/java…这样的语言中有块级作用域的,即在语法块中定义的变量,在语法块外面是无法访问到的。 那么,js要怎么去模拟像C这样的块级作用域呢?...*匿名函数外**无效,在匿名函数外,i就被销毁了 } })(); console.log(i);//输出:undefined } 在函数内部创建一个匿名函数,就相当于在函数内部创建了一个私有作用域
块级作用域 在es6(es2015)之前, 也就是es5中,作用域只有两种: 1. 全局作用域 2....= 6; 上面代码中,变量 tem 会发生变量提升,即脚本开始运行时,变量foo已经存在了,但是没有值,所以会输出undefined。...在es6中新增了块级作用域,新增的块级作用域通过 let 和 const 属性来体现: console.log(tem);//输出undefined let tem = 6; 下面介绍一下 let 和...const let 用法和 var 类似, 但是let声明的变量只在块级作用域内有效 function fun1() { let n = 5; if (true) { let n = 10...PI = 3.14; PI // 3.14 PI = 3; // TypeError: Assignment to constant variable. let和const有以下共同点 1.只在声明的块级作用域内有效
糟糕的是,尽管 Javascript 的代码貌似支持块级作用域,但实际上 Javascript 并不支持(就是因为有变量提升)。这个混淆之处可能成为错误之源。...所以在 ES6 中规定了 let 和 const 来支持块级作用域。但是,是不是真的提升就不存在了呢,可以看下面暂时性死区这部分。...const temp = 4;// 没有初始化报错 const t; // SyntaxError: Missing initializer in const declaration const 是块级作用域...事实上,当 JS 引擎检视下面的代码块有变量声明时,对于 var 声明的变量,会将声明提升到函数或全局作用域的顶部,而对 let 或 const 的时候会将声明放在暂时性死区内。...var foo = 1; { // 不会报错 let = 2; // other code } 同时因为是 let 和 const 是块级作用域,声明的变量在当前块使用完之后就会被释放
块作用域 尽管函数作用域是最常见的作用域单元,但是其他类型的作用域单元也是存在的,并且通过使用其他类型的作用域单元甚至可以实现维护起来更加优秀、简洁 除 JavaScript 外的很多编程语言都支持块作用域...for(var i = 0; i < 10; i++) { console.log(i); } 在 for 循环的头部定义了变量 i , 通常是因为只想在 for 循环内部的上下文中使用 i 这就是块级作用域的用处...,变量的声明应该距离使用的地方越近越好,并最大限度地本地化 块作用域就是对之前的最小授权原则进行扩展的工具, 块作用域 with with不仅是一个难以理解的结构,同时也是块作用域的一个例子(块作用域的一种形式...,因为所有变量都很安全地被限制在块级作用域内部。...块作用域 let/const 到目前为止,我们知道 JavaScript 在暴露块级作用域的功能中有一些奇怪的行为,如果仅仅时这样,那么 JavaScript 开发者多年来也不会将块级作用域当作非常有用的机制来使用了
本文将围绕JavaScript中的变量提升、作用域链、词法作用域、块级作用域、闭包和this进行详细介绍。...当baz函数被调用时,它可以访问foo函数作用域内的变量x,即使foo函数已经执行完毕。这是因为词法作用域的静态结构。 1.3 块级作用域 块级作用域是指由大括号{}包围的代码块内的作用域。...在ES6(ECMAScript 2015)之前,JavaScript只有全局作用域和函数作用域,没有块级作用域。这导致了一些问题,如变量提升、循环变量泄漏等。...ES6引入了let和const关键字,用于声明块级作用域的变量。这使得JavaScript具有了类似于其他编程语言(如C和Java)的块级作用域。...而let声明的变量y具有块级作用域,因此在if语句块内的赋值不会影响到外部的y。
(2)全局变量有 全局作用域,它的值可在整个程序中访问和修改。 (3)如果变量在函数内没有声明(没有使用 var 关键字),该变量为全局变量。...四、全局变量 1、在函数定义外声明的变量是全局变量;全局变量有全局作用域,它的值可在整个程序中访问和修改。 ? 2、如果变量在函数内没有声明(没有使用 var 关键字),该变量为全局变量。 ?...六、块级作用域 6.1 概念 块级作用域指在If语句,switch语句,循环语句等语句块中定义变量,这意味着变量不能在语句块之外被访问。...6.2 var 不支持块级作用域 (1)在If等语句块中,定义的变量从属于该块所在的作用域,和函数不同,他们不会创建新的作用域。 ?...6.3 let和const (1)为了解决块级作用域,ES6引入了 let 和 const 关键字,可以声明一个块级作用域的变量。 ? (2)全局作用域的生存周期与上述应用相同。
:let let可以看做是更完美的var 2.var 1.var var在声明一个变量时,该变量只有在函数中才有自己的作用,在if和for中没有自己的作用域。...,a生效的区域只在这个函数内,外部打印a会显示a is not defined,因为a不存在在外部 这就是作用域的作用 声明在if或for中的变量没有自己的作用域 3.var-if if...(true) { var a = 123; console.log(a); } console.log(a); 因为if没有作用域的概念...在for中的i是没有自己的作用域的,且js是异步执行,在js执行完后,才开始渲染页面,那就意味着我们在点击已经渲染出的button时,for循环已经遍历到最后一个,且这个for中的i没有自己的作用域,他是被共享的...那这时候,为了实现效果就会引入函数(因为var在函数中有自己的作用域),借助函数的作用域让每个i都有自己的作用域,点击按钮出现相应序号。这就是我们js常用的闭包。
这种函数是在JavaScript 的变量作用域影响下出现的。...自执行函数 var v = "hello"; (function(){ console.log(v); var v = "world"; })(); 输出:underfined 1.2 块作用域...var v = "hello"; if(true){ console.log(v); var v = "world"; } 输出:hello ES6之前是没有块作用域这个概念了,这对编程产生了很大的影响...4. let关键字的使用 ES6以后,出现了个牛逼的关键字 -- let let关键字的出现,也象征着JavaScript出现了块级作用域。...没有let关键字前: 有了let关键字后:
领取专属 10元无门槛券
手把手带您无忧上云