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代码的整体运行分成:词法分析和运行期。
执行之前,先有一个“词法分析过程”;执行时才进行赋值。
词法分析→→代码运行(赋值操作)→→输出结果。
相关文章推荐
- 简单javascript可以起到很大作用
- jsp与javascript结合用以处理confirm确认达到传递参数到另一个页面的作用
- Javascript !!的作用
- javascript中$符号的作用和用法
- javascript作用域
- Javascript作用域
- Javascript中的作用域(scope)
- Javascript作用域原理
- Javascript中的作用域(scope)
- Javascript里面的$符号的作用
- 面向对象的 Javascript 语言特性:作用域
- Javascript中的作用域(scope)是什么?
- JavaScript中的作用域(Scope in JavaScript)
- Javascript 作用域以及执行顺序
- 面向对象的 Javascript 作用域
- JavaScript中defer的作用
- javascript中top的作用
- Javascript中的$符号的作用!
- Javascript 作用域使用说明
- JavaScript 库作用及对比介绍