javascript中的作用域和闭包详解

前端之家收集整理的这篇文章主要介绍了javascript中的作用域和闭包详解前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

一、JavaScript作用域

JavaScript变量实际上只有两种作用域,全局变量函数的内部变量。在函数内部任何一个地方定义的变量(var scope)其作用域都是整个函数体。 全局变量:指的是window对象下的对象属性。 作用域划分:基于上下文,以函数进行划分的,而不是由块划分的。 强调两点: 1. 在同一作用域中,JavaScript是允许变量的重复定义,并且后一个定义将覆盖前一个定义。 2. 函数内部如果不加关键字var而定义的变量,默认为全局变量

var scope="global";
function t(){
console.log(scope); //"undefined"
var scope="local"
console.log(scope); //"local"
}
t();
console.log(scope); //"global"

在变量解析过程中首先查找局部的作用域,然后查找上层作用域。在第一段代码函数当中没有定义变量scope,于是查找上层作用域(全局作用域),进而进行输出其值。但是在第二段代码函数内定义了变量scope(无论是在console之后还是之前定义变量,都认为在此作用域拥有变量scope),于是不再向上层的作用域进行查找,直接输出scope。但是不幸的是此时的局部变量i并没有赋值,所以输出的是undefined。

函数作用域的意思,可以将上述第二段代码重写如下: var scope="global"; function t(){ var scope; console.log(scope); scope="local" console.log(scope); } t();

由于函数作用域的特性,局部变量在整个函数体始终是由定义的,我们可以将变量声明”提前“到函数体顶部。

输出undefined,由于第1步只定义未赋值

var b; //第1步
function fun(){
b = "change";
}
fun(); //调用上述函数
alert(b); //输出change

当使用var声明一个变量时,创建的这个属性是不可配置的,也就是说无法通过delete运算符删除

二、作用域实例

以上就是本文的全部内容,希望对大家学习javascript程序设计有所帮助。

猜你在找的JavaScript相关文章