JavaScript的执行环境及作用域

1.执行环境

执行环境定义了变量或函数有权访问的范围。每个执行环境都有与之关联的变量对象,环境定义的所有变量和函数都保存在这个对象中。

全局环境:是最外围的一个执行环境,全局环境被认为是window对象,所有的全局变量和函数都是作为window对象的属性和方法创建的。
局部环境:比如函数,每个函数有自己的执行环境,进入一个函数执行的时候,函数的环境就会进入一个环境栈中。执行完之后,该函数的环境被栈弹出,在函数中的变量和函数定义也随之销毁。


2.作用域

当代码在一个环境中执行时,会创建变量对象的一个作用域

用途:保证该执行环境对有权访问的所有变量和函数能够进行有序访问

作用域的前端(第一个变量对象):就是当前执行环境的变量对象
作用域的下一个变量对象:来自包含前一个的环境的变量对象
作用域的下下个变量对象:来自包含前两个的环境的变量对象

作用域的最后一个对象:来自全局环境的变量对象

window(…(C(B的变量对象(A当前执行环境的变量对象))))

var color="blue"
var function() changecolor{
    if(color==="blue"){
        color="red";
    }
    else{
        color="blue";
    }
}
changecolor();
alert("now color is"+color); 

上述函数changecolor()的作用域包含两个变量对象:它自己本身环境的变量对象(其中定义着arguments对象)和全局环境的变量对象
即:(window(arguments))

  • 访问范围和搜索顺序:
var color="blue";
function changecolor(){
    var  anotherColor="black";
    function swapColor(){
        var tampColor=anotherColor;
        anotherColor=color;
        color=tempColor;
        //可以访问 color anotherColor tampColor
    }
    //可以访问color anotherColor
    swapColor();
}
//这里只能访问color
changeColor();

里能通过作用域链访问外,外不能访问里,
里可向外搜索作用域链以查询函数和变量,先在里搜索,再到外搜索。外不能向里搜索作用域链而进入另一个环境

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值