小米技术社区
小米技术社区管理员 关于小米

27岁,山西运城人,职业电商经理人,前端开发工作者,从事过网站建设、网络推广、SEO、SEM、信息流推广、二类电商、网络运维、软件开发,等相关电商工作,经验较为丰富,小米技术社区致力于为广大从事Web前端开发的人员提供一些力所能及的引导和帮助 ...[更多]

E-mail:mzze@163.com

Q Q:32362389

W X:xiaomi168527

小米技术社区大牛王飞 关于王飞

27岁,山西运城人,职业电商经理人,网络工程师兼运维,从事过运营商网络建设,企业网络建设、优化。数据中心网络维护等通过,经验丰富,座右铭:当自己休息的时候,别忘了别人还在奔跑。 ...[更多]

E-mail:wf_live@126.com

Q Q:3940019

微博:王小贱ss

小米技术社区设计小艳 关于小艳

大于花一样的年龄,河南郑州是我家,2010年在北京接触团购网,2011年进入天猫淘宝一待就是四年,如今已经将设计走向国际化(ps:误打误撞开始进入阿里巴巴国际站的设计,嘿嘿)五年电商设计,丰富经验,从事过天猫淘宝阿里各项设计,店铺运营,产品拍摄;我将我的经历与您分享是我的快乐!座右铭:越努力越幸运! ...[更多]

E-mail:97157726@qq.com

Q Q:97157726

标签云
精品推荐
  • 什么是闭包?js闭包的2个最大用途以及注意事项

    什么是闭包?js闭包的2个最大用途以及注意事项

    各种专业文献上的"闭包"(closure)定义非常抽象,很难看懂。简单的说,闭包就是能够读取其他函数内部变量的函数。由于在Javascript语言中,只有函数内部的子函数才能读取局部变量,因……
    199人已经看过了
您的位置:首页 > 前端开发 > Javascript > 原生JS

js中代码的运行方式(预编译过程和执行流程)

分类: 原生JS35个赞

js中代码的运行方式 以及 执行流程

js中代码的运行方式有2个过程

(1)预编译过程: 语法检测 -》 变量提升   -》 函数预加载

(2)执行过程:预编译通过,再一行一行从上到下执行代码

    

如果预编译过程中,如果有错误(编译错误),当前整个script中的代码不执行;继续找下一个script标签(所以共同开发的时候不要使用同一个script标签,这样可以更快排查出谁的错误)

如果执行过程中,如果有错误(执行错误),当前这个script标签中,出错之前的代码正常执行,之后的代码不执行;继续找下一个script标签

案例1:预编译过程中的错误

    var num = 100;
    console.log(num);
    //编译错误 变量名不能是数字开头
    var 100abc = 200;

案例2:执行过程中的错误

    var fn;
    fn(); //执行错误,fn不是函数或未定义
    console.log(300);


 印证:执行代码之前,先进行变量提升,再进行函数预加载


     var f1 = 100;
    function f1(){
    console.log(200);
     }
    //现在f1是什么
    console.log(f1);  //结果100


    如果存在 同名的变量和函数名,始终是后来的覆盖前面的。(后来,是按照以下的顺序:)

    顺序: 先声明变量,再定义函数,最后进行赋值

    var f1;
    function f1(){
        console.log(200);
    }
    //现在f1是什么
    console.log(f1);  //结果直接为f1的表达式
    //现在f1是什么
    f1 = 100;
    console.log(f1); //结果为100


    /以下写法是,先定义了函数,再声明变量; 实际执行流程中,会先声明变量,后定义函数

    function f1(){
        console.log(200);
    }
    var f1;
    console.log(f1);


小米技术社区

本站内容均为小米原创,转载请注明出处:小米技术社区>> js中代码的运行方式(预编译过程和执行流程)