作用域
划分为全局和函数作用域。
var a=10;
function test(){
console.log(a);
}
变量a和函数test都直接暴露在外边。因此这两者都属于全局作用域。而test的函数体,则属于函数作用域。
作用域不同的变量访问范围
上述代码,test属于全局作用域,他内部又报了个函数作用域。这样一来就形成了作用域嵌套。即全局作用域里边嵌套函数作用域。
在函数作用域里边可以访问全局作用域的变量。反之不行。
1.正例
2.反例
注意:当发生作用域嵌套时,只能里访问外,反之不行。
作用域嵌套
针对全局作用域和函数作用域,函数作用域和其他函数作用域。
针对上述运行结果简单说明。执行代码是在运行阶段,在代码的分词阶段和解析阶段,变量a仍然会被获取。并且系统会给它一个undefined.
第一次执行console.log方法的时候,变量a还没有被赋值为一个函数,但是JavaScript引擎还是会把它提取出来并放入全局作用域,并且默认给它一个undefined。这个赋值语句把一个匿名函数赋给了变量a,那么从此变量a就指向了这个函数,换句话说,一个名字叫作a的函数就已经产生了。这句话一旦执行,a就不再是undefined了,而是一个函数。接下来执行第二个console.log方法,这个时候a自然已经有值了,所以打印出来的是一个函数。
var a=1;
function test(){
var a;
var inner=function(){
console.log(a);
}
inner();
}
test();//undefined
解析:函数作用域里边嵌套了函数作用域,最里边的inner函数优先在自己作用域范围找,未找到,往外层的test作用域找,找到了,就不再往外继续找了。而test作用域范围只是定义尚未赋值。那么a就是undefined.