javascript函数声明

之前说的三种函数声明中(参见   javascript变量声明),使用Function构造函数的声明方法比较少见,我们暂时不提。function func() { }和var func = function() { }除了在声明提升中有所不同之外也没有其他不同,我们合并起来一起看。我们在这里着重讲一个东西——匿名函数。

匿名函数顾名思义,就是没有名字的函数。它的形式就是function() { }。请注意和之前说的两种方式的区别,这里并没有赋值给任何变量,也就是说,没有指向这个函数的引用,我们无法在其他地方调用这个函数,也就是说,这种函数的使用价值只有一次。当我们把匿名函数赋值给其他变量时,就变成了var func = function() { }。是不是很熟悉?没错,就是我们之前说的变量声明的方法。而如果func是隐式声明的话,那么,这个函数就变成了全局函数。

匿名函数使用非常广泛,它常用于只执行一次的函数,例如排序函数,我们可以这样来写:

[javascript]  view plain  copy
  1. var a = [2,1,4,7,5];  
  2. a.sort(function(num1, num2) {  
  3.     return num1 > num2;  
  4. })  
我们传了个匿名函数作为参数,因为这个函数只适用于这个地方,而无法用在其他地方。但如果是类似的地方也用了类似的函数,例如我们需要两次排序:

[javascript]  view plain  copy
  1. var a = [2,1,4,7,5],  
  2.     b = [4,2,6,4,1];  
  3. function sortDesc(num1, num2) {  
  4.     return num1 > num2;  
  5. }  
  6. a.sort(sortDesc);  
  7. b.sort(sortDesc);  
我们就可以把这个匿名函数剥离出来赋给一个function类型的变量,达到重复利用的目的。

由上面这个例子我们可以看出匿名函数的优劣。坏处很明显,就是无法再次利用;好处是减少了声明的消耗(当然,如果有两次以上的利用的话,当然是声明的消耗更少)。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值