ES6 の 块级作用域

let实际上为 JavaScript 新增了块级作用域。

function f1() { let n = 5; if (true) { let n = 10; } console.log(n); // 5 } 

上面的函数有两个代码块,都声明了变量n,运行后输出 5。这表示外层代码块不受内层代码块的影响。如果两次都使用var定义变量n,最后输出的值才是 10。

ES6 允许块级作用域的任意嵌套。

{{{{{let insane = 'Hello World'}}}}}; 

上面代码使用了一个五层的块级作用域。外层作用域无法读取内层作用域的变量

{{{{ {let insane = 'Hello World'} console.log(insane); // 报错 }}}}; 

内层作用域可以定义外层作用域的同名变量。

{{{{ let insane = 'Hello World'; {let insane = 'Hello World'} }}}}; 

块级作用域的出现,实际上使得获得广泛应用的立即执行函数表达式(IIFE)不再必要了。

// IIFE 写法
(function () { var tmp = ...; ... }());  // 块级作用域写法 { let tmp = ...; ... }

转载于:https://www.cnblogs.com/cheeseCatMiao/p/9371202.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值