• JavaScript --- 预编译


    今天复习了关于JavaScript预编译这一块的知识点,很基础也很重要。

    关于预编译

    函数声明整体提升(如果你写一个函数声明,不管你写在哪里,系统总会把函数的声明提到逻辑的最前面) 

    变量 声明提升     eg:  var a = 123;  那么 变量声明就会提升到最前面(进行拆分):  var a     a = 123

    预编译发生在函数执行的前一刻

    1. 暗示全局变量(imply global): 即任何变量,如果变量未经声明就赋值,此变量就为全局对象所有。

    eg: a = 123;

    eg: var a = b = 123;  先把123赋给b,再把b的值赋给a

    2. 一切声明的全局变量,全是window的属性

    eg:var a = 123;  =====> window.a = 123;

    那么在预编译的过程中发生了什么呢?  首先创建了  AO 对象 。

    1. 创建AO对象 -----  Activation Object(执行器上下文)

    2. 找形参和变量声明,将变量和形参名作为AO属性名,值为undefined

    3. 将实参值和形参统一

    4. 在函数体里面找函数声明,值赋予函数体

    预编译不仅发生在函数体里,它还发生在全局  比如:

    console.log(a)    // undefined  (因为函数声明提升)

    var a = 123; 

    实例代码:

     

     

  • 相关阅读:
    intel cpu 架构
    nginx-nagios-pnp4nagios-nrpe安装配置过程
    iostat 命令detail
    nagios环境
    编译安装PHP 5.3.13
    nagios支持PNP图形显示
    nagios配置安装
    在xp下禁用media sense
    linux awk常用命令【转载】
    sed命令解析[转载]
  • 原文地址:https://www.cnblogs.com/lovekiku123/p/11645139.html
Copyright © 2020-2023  润新知