JS定义函数的两种方式:函数声明和函数表达式

本文探讨了函数声明提升的概念,解释了为何函数声明可以在调用前存在,并对比了函数表达式的行为。通过示例代码详细说明了这两种定义方式的区别。

函数声明

  关于函数声明的方式,它的一个重要的特性就是函数声明提升(function declaration hoisting),意思是在执行代码之前会先读取函数声明。这就意味着可以把函数声明放在调用它的语句后面,如下所示:

1             sayHi();
               //在调用语句的后面声明函数(function declaration hoisting)
2             function sayHi () {
3                console.log("Hello World");
4             } 

  

 函数表达式

  有多种表达方式,下面是最常见的一种:

 var s = function (agr1, arg2) {
      console.log(arg1 + '  ' + arg2);
  } 

按照书中所说,函数声明语句,声明函数实际是声明了一个变量f,然后将一个声明的函数对象赋值给变量f,变量的声明有提至所有代码顶部的特点,故函数声明语句声明的函数可以在声明之前调用。

 

至于为什么同样是将一个函数赋值给一个变量,函数表达式却不能提到前面呢?我们来分析下:

var s = function(arg1, arg2) {};

  

可以拆分为:

var s;
s = function (arg1, arg2) {}

  

其中 var s 被提前声明了,但 s = xxxx 是要在运行到这里的时候才进行。

 

转载于:https://www.cnblogs.com/yourstars/p/6121262.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值