了解作用域
引擎:负责JavaScript程序的编译及执行过程
编译器:负责语法分析及代码生成
作用域:负责收集并保护所有申明的标识符
作用域的嵌套:一个块或者函数嵌套在另一个块级作用域中时,就产生了块级作用域的嵌套。因而在以后作用域中无奈找到某个变量时,引擎就会在外层的作用域查找,直到找到该变量或者到达最外层作用域(全局作用域)为止。
var value=1;function bar1(){ var value=2; function foo1(){ console.log(value); } foo1();}bar1();//2
词法作用域:一个变量和函数的词法作用域取决于该变量或函数申明的中央,写在哪词法作用域就在该块作用域。
var value=1;function foo2(){ console.log(value);}function bar2(){ let value=2; foo2();}bar2();//1
为什么两者的后果不同呢?
这是因为JS采纳的是词法作用域,及变量或函数的作用域是由申明时地位决定的。对于foo1,它的作用域是bar1所以后果为2,对于foo2,它在申明时作用域是在window中,所以查找时foo2外部没有value,向外查找window中value