js的变量提升

2019-06-17  本文已影响0人  泉泉泉泉泉泉

举个荔枝:

function test() {
  a = 5;
  console.log(a);
  console.log(global.a); // node 环境
  var a = 10;
  console.log(a);
}
test();

输出结果:

5
undefined
10

再举个荔枝:

function test2() {
  function a() {}
  var a;
  console.log(a);                //打印出a的函数体

  var b;
  function b() {}
  console.log(b);                 //打印出b的函数体 

  // !注意看,一旦变量被赋值后,将会输出变量
  var c = 12
  function c() {}
  console.log(c);                 //12
  
  function d() {}
  var d = 12
  console.log(d);                //12
}
test2();

输出结果:

[Function: a]
[Function: b]
12
12

总结:变量解析的顺序

一般情况下,会按照最开始说的四种方式依次解析

也有例外:

上一篇下一篇

猜你喜欢

热点阅读