JS基础学习笔记(三)

1、全局变量

var color = "blue"; 
function changeColor(){
    var anotherColor = "red"; 
    function swapColors(){
        var tempColor = anotherColor;
        anotherColor = color;
        color = tempColor;      // 这里可以访问 color、anotherColor 和 tempColor
     }  
    // 这里可以访问 color 和 anotherColor,但不能访问 tempColor 
     swapColors();
} 
// 这里只能访问 color changeColor(); 

      对于这个例子中的 swapColors()而言,其作用域链中包含 3个对象:swapColors()的变 量对象、changeColor()的变量对象和全局变量对象。swapColors()的局部环境开始时会先在自己的 变量对象中搜索变量和函数名,如果搜索不到则再搜索上一级作用域链。

2、没有块级作用域 

javascript与C、C++等不同,并没有所谓的块级作用域,javascript的作用域是相对函数而言的。当函数执行完毕后,局部活动对象就会被销毁。

使用 var 声明的变量会自动被添加到最接近的环境中。在函数内部,最接近的环境就是函数的局部环境;在 with 语句中,最接近的环境是函数环境。如果初始化变量时没有使用 var 声明,该变量会自动被添加到全局环境。

3、闭包

匿名函数与闭包的区别,因此经常混用。闭包是指有权访问另一个 函数作用域中的变量的函数。创建闭包的常见方式,就是在一个函数内部创建另一个函数。

function createFunctions(){
    var result = new Array(); 
    for (var i=0; i < 10; i++){
        result[i] = function(){
            return i;// 实际上,每个函数都返回 10,而不会返回0、1、2、3……
        };
    }
    return result; 
}  
 

 闭包只能取得包含函数中任何变量的 后一个值。闭包所保存的是整个变量对象,而不是某个特殊的变量。

function createFunctions(){
    var result = new Array(); 
    for (var i=0; i < 10; i++){
        result[i] = function(num){
            return function(){
                return num;
            };
        }(i);
    }
    return result; 
} 

      这次没有直接把闭包赋值给数组,而是定义了一个匿名函数,并将立即执行该匿名函数的结果赋 给数组。这里的匿名函数有一个参数 num,也就是终的函数要返回的值。在调用每个匿名函数时,我 们传入了变量 i。由于函数参数是按值传递的,所以就会将变量 i 的当前值复制给参数 num。而在这个 匿名函数内部,又创建并返回了一个访问 num 的闭包。这样一来,result 数组中的每个函数都有自己 num 变量的一个副本,因此就可以返回各自不同的数值了。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值