JavaScript作用域
var的本质:【声明变量 var】
var a = 3; // 声明a变量并赋值。
b = 3; // 只是一个"赋值"操作。[如果函数内没有找到,则相当于声明了一个全局变量]
不要狭隘的理解为:声明了一个全局变量。(☆函数内如果有,则只是函数内的变量)。
作用域的特点
在JS中,函数嵌套是非常普遍的,在函数嵌套中对变量是如何寻找的?
答:首先在函数内部寻找,寻找不到则往外层寻找,直到全局。
function t1(){
var d;
function t2(){
d = 5;
e = 6;
}
t2();
}
t1();
console.log(e);//6
console.log(d);//d is not defined
console.log(window.d);//undefined
注意: 以window.xxx引用全局变量,寻找不到;作为某个属性不存在,返回undefined
(变量存在,但是没有值,相当于值为undefined)
直接以xxx引用某变量,寻找不到;则是报:xxx is not defined 错误。
/*极容易出错,又经常出现的题目*/
var str1 = 'global';
function t1(){
console.log(str1);
console.log(str2);
str2 = 'local';
}
t1();
//global
//str2 is not defined
JS代码自上往下执行,但js代码的整体运行分成:词法分析和运行期。
执行之前,先有一个“词法分析过程”;执行时才进行赋值。
词法分析→→代码运行(赋值操作)→→输出结果。