js中变量的作用域
2017-04-20 16:27
218 查看
首先要明确一点:javascript没有块级作用域。函数是javascript唯一拥有自身作用域的结构。
其次是 javascript的变量声明具有hoisting机制,JavaScript引擎在执行的时候,会把所有变量的声明都提升到当前作用域的最前面。注意这里仅仅提升“变量的声明”。
什么是变量的声明呢?从C++谈起:
声明宣称一个名字的存在,定义则为这个名字分配存储空间,而初始化则是为名字分配的存储空间赋初值。
用C++表述这三个概念:
int i;//这是声明并定义名字i,为i分配存储空间
i = 0;//这是初始化名字i,为其赋初值为0
在javascript中:
var v;//声明变量v
v = "hello";//(定义并)初始化变量v
所以当你写一个下面的程序时: 输出结果会是:undefined
var v = "hello";
function a(){
console.log(v);
var v = "world";
};
a();
因为此程序在执行时,在function作用域内,变量v的声明被提升了。所以最初的代码相当于:
var v = "hello";
function a(){
var v;
console.log(v);
v = "world";
};
a();
其次是 javascript的变量声明具有hoisting机制,JavaScript引擎在执行的时候,会把所有变量的声明都提升到当前作用域的最前面。注意这里仅仅提升“变量的声明”。
什么是变量的声明呢?从C++谈起:
声明宣称一个名字的存在,定义则为这个名字分配存储空间,而初始化则是为名字分配的存储空间赋初值。
用C++表述这三个概念:
int i;//这是声明并定义名字i,为i分配存储空间
i = 0;//这是初始化名字i,为其赋初值为0
在javascript中:
var v;//声明变量v
v = "hello";//(定义并)初始化变量v
所以当你写一个下面的程序时: 输出结果会是:undefined
var v = "hello";
function a(){
console.log(v);
var v = "world";
};
a();
因为此程序在执行时,在function作用域内,变量v的声明被提升了。所以最初的代码相当于:
var v = "hello";
function a(){
var v;
console.log(v);
v = "world";
};
a();
相关文章推荐
- 注意细节js变量作用域
- js 变量作用域
- js变量作用域的陷阱
- JS变量作用域
- JS之 函数模仿块级作用域,私有变量,模块模式
- js变量作用域及可访问性的探讨
- Js作用域链及变量作用域
- js变量作用域
- 深入理解JS变量作用域
- js中变量的作用域
- Js整理备忘(01)—— 变量作用域
- js跨域访问:js变量作用域
- Js 整理备忘(01)—— 变量作用域
- js的变量作用域
- JS。某变量作用域。
- js变量作用域及可访问性的探讨
- 变量的作用域js
- 有关js的变量作用域和this指针的讨论
- js变量作用域及可访问性的探讨
- JS作用域为“函数级作用域”,记住最简明的一句“函数中声明的所有变量,无论是在哪里声明的,在整个函数中它们都是有定义的。”QQ253079952