浅谈Js作用域以及执行期上下文

作为一个爱美丽也爱学习的程序媛,现在和大家聊一聊js作用域以及执行期上下文那些事儿、、、

作用域

这个有点不知道怎么说,感觉这个名词已经够直白了,作用域顾名思义就是其作用范围,如下代码所示:


 
 
  1. var a = 'hello' ;
  2. function demo1 (){
  3. var b = 0;
  4. }
  5. console.log(a); //hello
  6. console.log(b); //报错 Uncaught ReferenceError: b is not defined

这就是作用域导致的错误,变量b在函数demo1中定义,属于局部变量,只能在demo1中才可以被调用,而变量a定义在最外层,即全局,任何地方都可以使用这个变量,顺便还想提一下的是变量提升、函数声明提升以及函数表达式声明提升。


 
 
  1. console.log(a) //undefined
  2. console.log(demo1) //ƒ demo1(){ console.log("nice"); }
  3. console.log(demo2) //undefined
  4. var a = 10 ;
  5. function demo1(x,y){
  6. var aa = 10;
  7. x="hello";
  8.         function demo3(){
  9.             console.log("我是demo3");
  10.         }
  11.         var demo4 = function (){
  12.             console.log("我是demo4");
  13.         }
  14. console.log("nice");
  15. }
  16. var demo2 = function(){
  17. var cc = 20 ;
  18. console.log("not nice");
  19. }
  20. demo1();

 

Javascript是解释性语言,解释一行执行一行,但是在解释之前,浏览器会通篇扫描一下整体的语法结构是否符合规则,否则将不会解释代码,直接报错。

 

在函数demo1要执行,但还没执行的一刻,系统会创建一个AO对象。

 

  • 第一步    创建AO对象

 
 
  1. AO{

 

  • 第二步     将函数内所有的形参和变量声明存储到AO对象中

 
 
  1. AO{
  2. x:undefined,
  3. y:undefined,
  4. aa:undefined,
  5. demo3:function demo3(){......},
  6. demo4:unedfined
  7. }
  • 第三步     将函数内所有的形参和变量声明存储到AO对象中

 
 
  1. AO{
  2. x:"hello",
  3. y:undefined,
  4. aa:10,
  5. demo3:function demo3(){......},
  6. demo4:function (){console.log("我是demo4"); }
  7. }
  • 第四步     将所有函数声明和函数名作为AO对象中的Key,函数的整体内容作为value,存储到AO对象中(注:由于这是最后一个步奏,所以优先级最高,当函数声明的函数名与变量的名字相同的情况下,最终函数的整体内容会覆盖原先变量中的内容 )

 
 
  1. AO{
  2. x:"hello",
  3. y:undefined,
  4. aa:10,
  5. demo3:function demo3(){......},
  6. demo4:function (){console.log("我是demo4"); }
  7. }


所以......在函数开始执行后调用的都是AO中存储的对象,还有GO,GO面对的是window对象,所有的函数都至少又两个执行期上下文,一个是全局的GO,还有一个本身的AO,当访问函数内部变量时,函数会首先从自己的执行期上下文自上而下的搜索,如果没有,就会到全局的GO中寻找,当函数执行结束,函数指向AO的指针则会断掉,等到再次执行函数时,又会生成一个新的AO对象。

这个到这就结束了,如果其中又说的不对的地方,欢迎指出!!!

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值