js函数声明的提升顺序_技术学院_宜昌市隼壹珍商贸有限公司

您好,欢迎访问宜昌市隼壹珍商贸有限公司

400 890 5375
当前位置: 主页 > 新闻动态 > 技术学院

js函数声明的提升顺序

发布时间:2025-11-12  |  点击率:
函数声明优先提升且覆盖同名变量,多个同名函数后者覆盖前者,函数表达式仅变量提升。

在JavaScript中,函数声明的提升(hoisting)是指函数声明会在代码执行前被“提升”到当前作用域的顶部。理解函数声明的提升顺序,有助于避免运行时错误和意料之外的行为。

函数声明优先于变量声明提升

在同一个作用域中,函数声明会被优先提升,并且优先级高于变量声明。这意味着:

  • 函数声明会完整地被提升到作用域顶部。
  • 变量声明也会被提升,但不会赋值(初始化留在原地)。
  • 如果函数和变量同名,函数声明会先被提升并覆盖变量声明(在提升阶段)。
示例:

console.log(typeof foo); // "function"
foo(); // 能正常执行

var foo = "hello";
function foo() {
  console.log("I am a function");
}

上面代码实际执行时等价于:

function foo() {
  console.log("I am a function");
}
// var foo; (声明被提升,但赋值不提升)
console.log(typeof foo); // "function"
foo(); // 正常调用
foo = "hello"; // 此处才是赋值

多个函数声明同名时,后声明的覆盖前面的

当存在多个同名函数声明时,提升过程中后面的函数会覆盖前面的:

foo(); // 输出 "later"

function foo() {
  console.log("earlier");
}
function foo() {
  console.log("later");
}

因为两个函数都会被提升,但第二个函数声明会覆盖第一个。

函数表达式不会完全提升

注意:只有函数声明会被完整提升,函数表达式(尤其是匿名函数赋值给变量)只提升变量名,不提升函数体:

foo(); // 报错:foo is not a function

var foo = function () {
  console.log("I'm an expression");
};

这等价于:

var foo;
foo(); // 此时foo是undefined
foo = function () {
  console.log("I'm an expression");
};

总结:

JavaScript中函数声明提升的顺序规则如下:

  • 所有函数声明优先被提升到作用域顶部。
  • 同名函数声明中,后面的覆盖前面的。
  • 变量声明也提升,但不会影响已提升的函数(除非后续赋值覆盖)。
  • 函数表达式遵循变量提升规则,函数体不会提升。
基本上就这些。

全国统一服务电话

400 890 5375

电子邮箱:879577@qq.com

公司地址:宜昌市西陵区黄河路5号三峡明珠10栋1051室

咨询微信

TEL:13680874598