以下代码执行后果是什么
<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
如果有什么不对的中央,欢送指出!