js代码解析原则
首先js引擎在读取js代码时会进行两个步骤,第一个步骤是解释,第二个步骤是执行。
所谓解释就是会先通篇扫描所有的Js代码,然后把所有声明提升到顶端,第二步是执行,执行就是操作一类的。
例子1:
1 |
<script type="text/javascript"> |
以上代码输出 undefined
原因: 变量提升(把变量声明提升到当前执行环境的最顶端)
上段代码相当于:
1 |
var a; |
例2:
1 |
foo(); |
结果输出: aaa
原理:函数声明提升 (函数声明提升直接把整个函数提到执行环境的最顶端)
相当于:
function foo(){
console.log(“aaa”);
}
foo();
变量提升只提升函数名 而函数提升会提升整个函数题 注意:函数提升在变量提升上面。
例3:
1 |
foo(); |
运行结果是: foo is not a function
原因: 还是进行了变量提升
相当于:
1 |
var foo; |
上面代码输出undefined 是因为变量提升后并没有赋值因此输出undefined
输出foo is not a function 原因是:js解析遇到 foo()时会默认当做函数来解析
例4:
1 |
console.log(foo); |
输出结果:
原理:
相当于:
1 |
function foo(){ |
注意: 函数提升在变量提升上面,第一个console.log(foo);为什么会输出函数题呢,原因在于 var foo; 并未有赋值只是声明,因此他会调用上面的值
例如:
1 |
var b=10; |
但是更改后:
1 |
var b=10; |
作者:朽木自雕也
链接:https://www.jianshu.com/p/d4b88723cd12
来源:简书
简书著作权归作者所有,任何形式的转载都请联系作者获得授权并注明出处。




近期评论