• JS执行顺序问题


    JavaScript执行引擎并非一行一行地分析和执行程序,而是一段一段地分析执行的。而且在分析执行同一段代码中,定义式的函数语句会被提取出来优先执行。函数定义执行完后,才会按顺序执行其他代码。

    先看看两个例子:

    例子1:

    var hello = function(){

    alert('hello,zhangsan');

    }

    hello();//第一次调用,输出“hello,zhangsan”

    var hello = function(){

    alert('hello,lisi');

    }

    hello();//第二次调用,输出“hello,lisi”

    例子2:

    function hello(){

    alert(‘hello,zhangsan’);

    }

    hello();//第一次调用,猜猜输出什么内容?

    function hello(){

    alert(‘hello,lisi’);

    }

    hello();//第二次调用,猜猜输出什么内容?

    在例子2中,两次调用都会输出相同的内容“hello,lisi”。同样是声明两个相同名称的函数,为什么调用的结果却不一样呢?

    这 就是JavaScript执行顺序导致的。JavaScript执行引擎并非一行一行地分析和执行程序,而是一段一段地分析执行的。而且在分析执行同一段 代码中,定义式的函数语句会被提取出来优先执行。函数定义执行完后,才会按顺序执行其他代码。也就是说,在第一次调用hello函数之前,第一个函数语句 定义的代码已经被第二个函数定义语句的代码覆盖了,这就是为什么在例子2中第一次调用hallo时,也会输出后面定义的函数内容的原因了。

  • 相关阅读:
    twfont
    判断数组中某个元素的个数
    vue swiper中的大坑
    this指向问题
    vue.nextTick简单的用法
    类图解析
    设计模式
    设计模式
    Http Notes
    VS Notes
  • 原文地址:https://www.cnblogs.com/lidedong/p/9675572.html
Copyright © 2020-2023  润新知