JS 变量提升、执行上下文、作用域链

JS 变量提升、执行上下文、作用域链

  一、执行上下文(execute context)EC 理解:代码的执行环境 时机:代码正式执行之前会进入到执行环境,代码执行结束销毁 工作:       1.创建变量对象           (1)变量           (2)函数及函数的参数           (3)全局:window             (4) 局部:抽象的但是确实存在       2.确认this指向           (1)全局:this ---> window             (2) 局部:this----> 调用其的对象       3.创建作用域链             当前变量对象+父级作用域链+。。。       4.扩展:          ECObj = {             变量对象:{变量,函数,函数的形参},             scopechain:父级作用域链 + 当前的变量对象,             this:{window || 调用其的对象}          } 二、 作用域链:上下文中代码执行时会创建变量对象的一个作用域链。                 作用域链决定者各级上下文中代码访问变量和函数的顺序。                 代码正在执行的上下文的变量对象始终位于作用域链的最前端。                    作用域链的下一个变量对象来自包含上下文,再下一个变量对象来自下一个包含上下文。                 以此类推直至全局上下文,全局上下文的变量对象始终是作用域链的最后一个变量对象。         作用域链增强:执行上下文主要有全局上下文和函数上下文两种(eval()调用内部存在第三种上下文),                          但有其他方式来增强作用域链。某些语句会导致在作用域链前端临时添加一个上下文,                             这个上下文在代码执行后会被删除 。                         (1)try/catch语句的catch块                           (2)with语句

 

   
上一篇:爆破与dvwa靶场


下一篇:利用js完成小球快跑案例