zoukankan      html  css  js  c++  java
  • 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; 

    实例代码:

     

     

  • 相关阅读:
    动态字节码技术Javassist
    自己实现简单版的注解Mybatis
    AOP实现事务和记录日志
    自己实现简单版SpringMVC
    静态变量
    docker安装nginx , 安装mysql5.6,安装redis3.2
    Worker Thread模式
    linux 安装jdk
    dockfile构建自己的tomcat
    docker使用2
  • 原文地址:https://www.cnblogs.com/lovekiku123/p/11645139.html
Copyright © 2011-2022 走看看