四、说说你对 JavaScript 的作用域的理解。什么是作用域链?
在 JavaScript 中有两种作用域类型:
1. 局部作用域:只能在函数内部访问它们
2. 全局作用域:网页的所有脚本和函数都能够访问它
JavaScript 拥有函数作用域:每个函数创建一个新的作用域。
作用域决定了这些变量的可访问性(可见性)。
函数内部定义的变量从函数外部是不可访问的(不可见的)。
作用域链:
当查找变量的时候,会先从当前上下文的变量对象中查找,
如果没有找到,就会从父级(词法层面上的父级)执行上下文的变量对象中查找,一直找到全局上下文的变量对象,也就是全局对象。
这样由多个执行上下文的变量对象构成的链表就叫做作用域链
五、 解释下 var,let 和 const 的块级作用域★★★★
1.从预解析角度分析
let和const没有预解析,所以要求变量必须先定义在使用,如果定义之前使用会报错
var会做预解析,所以定义之前用和定义之后用都不会报错
2.重复的变量名
let和const在定义的时候不允许出现重复的变量名,重名直接报错
但是var在定义的时候出现重复的变量名是不报错的
3.块级作用域
var定义的变量是没有块级作用域的,只有函数的{}才能显示var的使用范围
let和const定义的是有块级作用域的
什么叫块级作用域?任何一个可以执行代码的{}都叫做块级作用域,都可以限制变量的使用范围
let和const的区别
4.修改值的问题
let定义的量后期值是可以修改的
const定义的量后期值不允许修改
let一般叫做变量 const一般叫做常量
一般我们获取元素都是在一开始获取依次,后期就再也不获取,再也不更改了,所以一般获取元素可以使用const去定义
5.初始值的问题
let定义的可以不写初始值,因为后期再赋值也可以
const定义的必须写初始值(因为const后期无法再重新赋值,如果一开始就不写初始值,以后就都没有,所以规定必须写)