js的学习之路(05)---预编译

js的学习之路(05)---预编译,第1张

        预编译:函数调用怎么运行代码的?
            1.分析代码是否正确 词法分析
            2.隐式 *** 作==>预编译 函数调用以后 运行代码之前
                 形实函运:
                 2.1函数每次调用都会生成一个对象:执行期上下文对象(AO对象)
                 2.2给AO对象添加成员:函数内部的局部变量和形参变量名(名字一样时不冲突) 作为AO对象的属性名
                 AO:{a:undefined}
                 2.3把传入的实参赋值给AO对象的属性
                 AO:{a:赋值}
                 2.4局部函数声明,赋值 把局部函数的名字让AO对象也有一个一样的属性名 把函数体赋值给这个属性
                 AO:{fn:function fn(){}}
            3.运行代码:预编译过的代码就不在运行
            
             全局作用域运行代码是 也有预编译==>全局预编译
             1.生成一个对象Global Object(GO)
             2.把所有的全局变量设置为GO的属性名
             3.把所有函数名作为GO的成员名,把函数体赋值给这个成员
             4.执行代码
            全局预编译==>不同的环境中运行js代码不一样
             GO对象的成员全部浅拷贝给环境对象window(node.js环境中没有这一步)
            扩展知识:console.log(a)访问的GO对象上的成员(作用域链中没有就报错)
                    //console.log(window.a)没有返回undefined
                    

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1297031.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-06-10
下一篇 2022-06-10

发表评论

登录后才能评论

评论列表(0条)

保存