以下代码执行后果是什么

<script>    console.log(a);    var a = 1;    console.log(a);    function a(){console.log(2)}    console.log(a);    var a = 3;    console.log(a);    function a(){console.log(4)}    console.log(a);    a()</script>

执行后果

为什么,咱们当初来剖析一下
进入到作用域之后,会产生什么事件?
首先,js 预解析
在以后作用域下,js运行之前,会把带有var和function关键字的办法当时申明,并在内存中安顿好,而后在从上到下顺次执行。
预解析只会产生在通过var定义的变量和function上。如果函数跟var变量重名,函数申明晋升比变量申明晋升的优先级高

1.预解析

而后js 逐渐执行
2.js 逐渐执行
而后找表达式(=,== ++, +-)去批改变量或者办法的值

预解析 a申明后果挨着笼罩后,
function a(){console.log(4)}

执行到倒数第二行 , a = 3,那么执行a(),会报错不是一个function

如果有什么不对的中央,欢送指出!