变量提升 快 还是 函数提升 快?


a()
function a() {
  console.log(1)
}
var a = function () {
  console.log(2)
}
a();

// 打印  1  2

很多博主 都说 :先打印 1 说明 函数提升快,并且 不会被 同名的变量申明 覆盖
原理:

var a = function () {
  console.log(1)
}
var a;  // 申明了变量,但是并没有覆盖函数申明
a();// 打印 1
a = function () {
  console.log(2)
}
a(); // 打印 2

那为啥不能是先申明变量呢?

var a;
var a = function () {
  console.log(1)
}
a();   // 1
a = function () {
  console.log(2)
}
a();  // 2

是不是 就没有 谁优先级高的说法,只是臆想的而已。
根本看不出来谁优先级高,只能看出 变量申明 不会 覆盖同名的 函数申明

按照js标准规则是函数声明先提升,变量声明再提升(如果之前已经有同名的函数,这个变量声明就无效了)
注意:变量只有声明提升,对变量的赋值不会提升。但函数声明提升会连定义的函数一起提升
提升后代码是

function a() { //函数声明先提升
  console.log(1)
}
var a; // 变量声明再提升,之前已经有同名的a函数,这个变量声明就无效了
a();// 打印 1
a = function () {
  console.log(2)
}
a(); // 打印 2

其实函数声明先提升,还是变量声明先提升,效果是一样的,你不用纠结这个问题
比如变量声明先提升,函数声明提升时也会覆盖同名的变量,效果是一样的

var a; // 变量声明先提升
function a() { //函数声明提升时也会覆盖同名的a变量
  console.log(1)
}
a();// 打印 1
a = function () {
  console.log(2)
}
a(); // 打印 2

如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!

img

同时提升,但函数会同时赋值。

您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!
PS:问答VIP年卡 【限时加赠:IT技术图书免费领】,了解详情>>> https://vip.csdn.net/askvip?utm_source=1146287632