一、作用域
1、什么是作用域
作用域就是一段代码可以起作用的范围。决定了变量的适用范围。
全局作用域
最外层的作用域叫做全局作用域。
函数作用域
js中可以通过函数来创建一个独立作用域称为函数作用域,函数可以嵌套,所以作用域也可以嵌套。
块级作用域
es6中新增了块级作用域(大括号,比如:if{},for(){},while(){}…)。
二、作用域链
当我们使用一个变量时,先在当前作用域查找,如果没找到就去他外层作用域查找,如果还没有,就再继续往外找,一直找到全局作用域,要么找到,要么报错,这就是作用域链。
三、自由变量
当前作用域没有定义的变量叫做自由变量。
四、变量提升
JavaScript 仅提升声明,而不提升初始化。如果你先使用的变量,再声明并初始化它,变量的值将是 undefined。
1:所有的声明都会提升到作用域的最顶上去。
2:同一个变量只会声明一次,其他的会被忽略掉。
3:函数声明的优先级高于变量申明的优先级,并且函数声明和函数定义的部分一起被提升。
五、变量提升
在定义的函数名和变量名相同的情况下,函数提升优先级高于变量的例子:
输出1,不会输出2。函数声明和变量声明都会被提升,但是需要注意的是函数会先被提升,然后才是变量。
var func;尽管出现在function func()之前,但它是重复的声明,会被忽略,因为函数声明会被提升到普通变量之前。
等同于这样:
注意:
1、只有声明本身会被提升,而赋值操作不会被提升。
2、变量会提升到其所在函数的最上面,而不是整个程序的最上面。
3、函数声明会被提升,但函数表达式不会被提升。