JAVASCRIPT之函数表达式

本文深入解析了JavaScript中函数声明与函数表达式的定义方式及其特性,包括函数声明的提升机制及函数表达式的匿名特性,帮助读者理解这两种定义函数的区别。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

函数表达式

在Javascript中定义函数的方式有两种: 一种是函数声明, 另一种是函数表达式。

函数声明语法如下:

function functionName (arg0, arg1, arg2) {
    //函数体
}

函数声明的一个重要特征就是函数声明提升,意思是在执行代码之前会先读取函数声明。这就意味着可以把函数声明放在调用它的语句后面。

sayHi();
function sayHi() {
    alert("Hi");
}

第二种创建函数的方式是使用函数表达式。 函数表达式有几种不同的语法形式,下面是最常见的一种形式。

var functionName = function(arg0, arg1, arg2) {
    //函数体
}

这种形式看起来好像是常规的变量赋值语句,即创建一个函数并将它赋值给变量functionName。这种情况下创建的函数叫做匿名函数, 因为function 关键字后面没有标识符。(匿名函数有时候也叫拉姆达函数。)匿名函数的name属性时空字符串。

function f1() {
}

alert("Function name -> " +  (function(){}).name);      //Function name ->
alert("Function name -> " + f1.name);                    //Function name -> f1
alert("Function name -> " +  (function f2(){}).name);   //Function name -> f2

函数表达式与其他表达式一样,在使用前必须先赋值。以下代码会导致错误。

sayHi();    //Uncaught TypeError: sayHi is not a function
var sayHi = function() {
    alert("Hi");
}

理解函数提升的关键,就是理解函数声明与函数表达式之间的区别。

 

备注: 摘取自《JAVASCRIPT高级程序设计:第3版》

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值