不一样的JavaScript(5)——变量作用域

原创 2013年12月05日 17:42:45

1. Javascript中没有块作用域,及if,for等定义的代码块不能限制变量的作用域。例如:

if(true) {
    var number = 10;
}
console.log(number);

for(var i = 0; i < 5; ++i) {
    // do something
}
console.log(i);

变量number尽管是定义在if {...}中,但一对大括号不能限制number的作用范围。在大括号的外面,number仍然有效,因此第一行输出是数字10。

同样,for {...}也不能限制变量i的作用范围。i在大括号外面仍然有效。因此上述代码的第二行输出是5。

2. 用var声明的变量的作用域在一个函数的内部,超出函数之外该变量不能引用。例如:

function add(num1, num2) {
    var sum = num1 + num2;
}

add(2, 3);
console.log(sum);

运行上述代码将出错,因为在函数add之外变量sum没有定义。

3. 如果变量的声明不是用var开头,那么该变量自动变成全局变量。尽管这些变量声明在一个函数体内,但它们在函数体外仍然能够引用:

function add(num1, num2) {
    sum = num1 + num2;
}

add(2, 3);
console.log(sum);

此时将输出5。

4. 如果用var在函数体内声明变量,不管在函数体什么位置声明变量,这些声明会自动提升到函数的最开始处。因此在函数体允许先使用变量后声明变量。例如:

function add(num1, num2) {
    sum = num1 + num2;
    console.log(sum);
    var sum;
}

add(2, 3);

在函数体add内部,我们先使用变量sum,后声明它。但这样没有问题,因为var sum会自动提升到函数最开始处。上述代码的输出为5。



javascript变量作用域

  • 2013年07月25日 20:48
  • 18KB
  • 下载

理解JavaScript变量作用域.pdf

  • 2011年05月01日 10:08
  • 1.21MB
  • 下载

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

先解释一下什么是“自由变量”。 在A作用域中使用的变量x,却没有在A作用域中声明(即在其他作用域中声明的),对于A作用域来说,x就是一个自由变量。如下图 如上程序中,在调用fn()...

变量作用域和定时器——Javascript 进阶知识整理

变量作用域和定时器 变量提升 JS的解释器在解释JS代码的时候会首先将代码都扫描一遍,将其中的变量和函数的声明提升到代码块的顶部,所以定义在代码后面的函数在前面代码就可以使用,变量也是如此,但是变量...
  • lqadam
  • lqadam
  • 2016年12月21日 15:59
  • 495

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

转载自:http://www.cnblogs.com/wangfupeng1988/p/3992795.html 先解释一下什么是“自由变量”。 在A作用域中使用的变量x,却没...

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】 先解释一下什么是“自由变量”。 在A作用域中使用的变量x,却没有在A作用域中声明(即在其他作用域中声...

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

原文地址:http://www.cnblogs.com/wangfupeng1988/p/3992795.html 先解释一下什么是“自由变量”。 在A作用域中使用的变量x,却没有在A作用域中声...

Javascript学习笔记04 ——变量,作用域,内存问题

基本类型值:表示简单的数据段,undefined null string number boolean 为基本类型,可以操作保存在变量中的实际的值。 引用类型:表示多个值构成的对象。保存在内存中。因...

深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

先解释一下什么是“自由变量”。 在A作用域中使用的变量x,却没有在A作用域中声明(即在其他作用域中声明的),对于A作用域来说,x就是一个自由变量。如下图 如上程序中,在调用fn()...

深入理解javascript原型和闭包系列 深入理解javascript原型和闭包(14)——从【自由变量】到【作用域链】

js 原型链 作用域链 执行上下文 this 闭包
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:不一样的JavaScript(5)——变量作用域
举报原因:
原因补充:

(最多只允许输入30个字)