函数和变量中的预解析

Posted qtbb

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了函数和变量中的预解析相关的知识,希望对你有一定的参考价值。

1.js引擎运行 js 分为两步,预解析   代码执行

  (1)预解析 js 引擎会把 js 里面的所有的 var 还有 function 提升到当前作用域的最前面

  (2)代码执行 按照代码书写的顺序 从上往下执行

2.预解析分为 变量预解析(变量提升) 和 函数预解析 (函数提升)

  (1)变量提升 就是把所有的变量声明提升到当前的作用域最前面   不提升赋值操作

  (2)函数提升  就是把所有的函数声明提升到当前作用域的最前面  不调用函数

案例1:(变量提升)

  console.log(num);   //undefined  

  var num=10;

  相当于:

    var num;

    console.log(num);

    num=10;

案例2:(函数提升)

  fn();   // 11

  function fn()

    console.log(11);

  

  相当于:

    function fn()

      console.log(11);

    

    fn();

案例3:(函数表达式)

  fun();   // 报错:fun is not a function

  var fun=function()

    console.log(22);

  

  相当于:

    var fun;

    fun();

    fun=function()

      console.log(22);

    

以上是关于函数和变量中的预解析的主要内容,如果未能解决你的问题,请参考以下文章

js 函数 /变量/ 以及函数中形参的预解析的顺序

JS——变量和函数的预解析匿名函数函数传参return

22.函数预解析变量与函数优先问题

浏览器的预解析过程

js之预解析

javascript的预解析与变量提升