javascript作用域链

函数是特殊对象,函数类对象
    function test(){

    }
test.[[scope]]    隐式属性

*每个js函数都是一个对象,对象中有些属性我们可以访问有些我们不能访问,
*这些属性仅供js引擎存取,[[scope]] 就是其中一个。
*[[scope]] 指的就是我们所说的作用域,其中存储了运行期上下文的集合;
*作用域链:[[scope]] 中所存储的执行期上下文对象的集合,这个集合呈链式链接,我们把这种链式链接叫做作用域链。
*
*运行期上下文:当函数执行时会创建一个为执行期上下文的内部对象,一个执行期上下文定义了一个函数执行时的环境,
*函数每次执行时对应的执行上下文都是独一无二的,所以多次调用一个函数会导致创建多个执行上下文,当函数执行完毕
*它所产生的执行上下文被销毁。
*test(){} //独立AO{},用完就销毁
*test(){}//再执行,重新创建一个独一无二的AO{},用完子销毁;
* 查找变量:从作用域链的顶端依次 向下查找;

function  a () {
    function b() {
        var b = 234;
    }
    var a = 123;
    b();
}
var glob = 100;
a();

* 函数定义完就有了a.name也就有了a.[[scope]]-->作用域链--> 0:GO{};
* GO{a:function(){},glob=100}
* a()执行前创建 AO{}就被放在作用域的最顶部;
* a.[[scope]]-->作用域链(scope)--> 0:AO{};
*  a.[[scope]]-->作用域链(scope)--> 1:GO{};
* 要找一个变量,就去他的作用域链去找,从顶端找到底端;所以先找顶部的OA
* a的执行产生了 b的创建,b有了自己的执行上下文OA{},放在作用域的最顶端
 
 
 
b函数被定义时拿(引用)的是a函数的AO{};当被执行时才创建自己的AO{},放在作用域的最顶端;最后打印a=0;


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值