您的位置:首页 > Web前端 > JavaScript

JavaScript作用域

2014-12-21 23:52 78 查看

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代码的整体运行分成:词法分析和运行期。

执行之前,先有一个“词法分析过程”;执行时才进行赋值。

词法分析→→代码运行(赋值操作)→→输出结果。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: