一.var的块级作用域
1. ES5及之前的版本
在前面的学习中,ES5和之前的版本中JS只会形成两个作用域:全局作用域和函数作用域。
PS:ES5及之前的版本没有块级作用域,在之前的版本中有一个块代码的定义,块代码和声明对象的字面量不一样。
ES5中放到一个代码中定义的变量,外面是可以访问的。
2.ES6版本
ES6中有块级作用域,但是下面这种还是能访问到。
因为块级作用域的限制针对于var类型变量是无效的,它对let、const类型有效。
二.let/const的块级作用域
在ES6中新增了块级作用域,并且通过let、const、function、class声明的标识符是具备块级作用域的限制的。
为了让块级作用域的限制生效,这里使用let声明的举例。
特殊点:function声明的变量。
在浏览器中打印的结果也是正常的。
没有报错并且还打印出来了函数中的内容,这是因为不同的浏览器有不同的实现,大部分浏览器为了兼容以前的代码,让function是没有块级作用域的,因此这是浏览器实现的问题,但是如果让浏览器只支持ES6的代码,那么这个函数就是访问不到的,并且报错显示函数是没有定义的。