函数声明与函数表达式

函数声明与函数表达式接下来的语句是函数 quack 的声明 因为已经处理过了 所以浏览器跳过声明 接着执行后面的条件语句

大家好,欢迎来到IT知识分享网。

函数声明

一个标准的函数声明,由关键字function 、函数名、形参和代码块组成。

有名字的函数又叫具名函数

举个例子:

function quack(num) { for (var i = 0; i < num; i++) { console.log("Quack!") } } quack(3) 

函数表达式

函数没有名称,而且位于一条赋值语句右边,被赋给一个变量。

在语句(如赋值语句)中,以这样的方式使用关键function时,创建的是函数表达式。

没有名称的函数又叫匿名函数

举个例子:

var fly = function(num) { for (var i = 0; i < num; i++) { console.log("Flying!"); } } fly(3) 

下面是一个关于如何区分函数声明和函数表达式的简单提示:

如果语句以function关键字开头,那么它就是一个函数声明,否则就是一个函数表达式。

(当function关键字在表达式中创建一个函数(有或没有名称)时,才是一个函数表达式。)

// 函数声明: 以 `function` 关键字开头 function sumA(a, b) { return a + b; } // 函数表达式: 不以 `function` 关键字开头 const mySum = (function sumB(a, b) { return a + b; }); // 函数表达式: 不以 `function` 关键字开头 [1, 2, 3].reduce(function sum3(acc, number) { return acc + number }); // 函数表达式 const sum = (function sumB(a, b) { return a + b; }); // 函数表达式 const myObject = { myMethod: function() { return 42; } }; // 函数表达式 const numbers = [4, 1, 6]; numbers.forEach(function callback(number) { console.log(number); // logs 4 // logs 1 // logs 1 }); 

在函数表达式中创建的函数有两种:

  1. 如果表达式内的函数没有名称,例如function() {return 42},则这是一个匿名函数表达式;
  2. 如果函数有名字,例如前面例子中的sumBcallback,那么这就是一个命名函数表达式

从更高的角度来看,函数声明对于创建独立的函数很有用,但是函数表达式作为回调很好。

现在,让我们深入了解函数声明和函数表达式的行为。

乍一看,函数声明和函数表达式差别不大,但实际上它们存在根本性差别。

要明白这种差别,首先需要研究一下浏览器在运行阶段如何处理代码。

举个例子,看看浏览器如何分析并执行网页中的代码。

var migrating = true; var fly = function (num) { for (var i = 0; i < num; i++) { console.log("Flying!") } } function quack(num) { for (var i = 0; i < num; i++) { console.log("Quack!") } } if (migrating) { quack(4) fly(4) }

分析浏览器如何执行代码

第一步:分析函数声明

在分析网页期间(执行任何代码之前),浏览器查找函数声明。找到函数声明时,浏览器创建相应的函数,并将得到的函数引用赋给与函数同名的变量。

函数声明与函数表达式

第二步:浏览器执行代码

处理所有的函数声明后,浏览器回到代码开头,开始按从头到尾的顺序执行代码。

 函数声明与函数表达式

第三步:继续执行

处理完变量fly后,浏览器继续往下执行。接下来的语句是函数quack的声明,因为已经处理过了,所以浏览器跳过声明,接着执行后面的条件语句。

函数声明与函数表达式

小结一下,浏览器的执行过程:

  1. 首先扫描代码,查找函数声明
  2. 分析函数声明(存储该函数,并创建一个与函数同名变量来存储指向该函数的引用)
  3. 处理完所有函数声明后,浏览器从头开始执行代码(按顺序处理各种函数变量)
  4. 碰到函数表达式时,同函数声明,需存储该函数,并将指向该函数的引用赋给表达式左边的变量

结论:函数声明与函数表达式的区别

函数声明 函数表达式
1 函数声明是完整的语句 函数表达式只是语句的一部分
2 函数命名时,创建一个与函数同名的变量,并让它指向函数 函数命名时,通常不给函数指定名称,因此需要在代码中将函数赋给一个变量,或以其他方式使用函数表达式
3 可以出现在代码的任何地方,函数声明创建的函数都是自己定义的,这被称为提升(hoisting) 函数表达式创建的函数要等到它执行后才被定义
4 函数将在执行代码前创建,即使未调用,也占用内存空间 函数将在运行阶段执行代码时临时创建,调用完,立即释放,所以更节省内存空间

讲了这么多,相信你对函数声明与函数表达式已经有了一定的了解,来做个题目试试水吧~

阅读以下代码,从上到下依次说出执行结果:

// 从上到下依次说出执行结果 var foo = function () { console.log("foo1") } foo() var foo = function () { console.log("foo2") } foo() function foo() { console.log("foo1") } foo() function foo() { console.log("foo2") } foo() 

具体答案,见下篇文章解答吧~(函数声明与函数表达式习题-CSDN博客)

引用文章:

一个例子讲清楚函数声明和函数表达式 – 知乎

免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://haidsoft.com/125990.html

(0)
上一篇 2025-09-22 16:45
下一篇 2025-09-22 17:00

相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注微信