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
如有帮助,请点击我的回答下方的【采纳该答案】按钮帮忙采纳下,谢谢!
同时提升,但函数会同时赋值。
您好,我是有问必答小助手,您的问题已经有小伙伴帮您解答,感谢您对有问必答的支持与关注!