JS精粹--匿名函数与自执行匿名函数

点此查看全部文字教程、视频教程、源代码

1. 函数也是一种类型

要理解匿名函数,首先需要理解函数也是一种类型。

所以函数可以赋值给变量,如下:

		// 将数字类型值赋给变量
        var num = 1;
        // 将函数类型值赋给变量
        var hello = function () {
            console.log("hello world");
        }
        // 执行num表达式
        num++;
        // hello
        hello();

由于数字类型和函数类型不同,数字类型可以进行运算,例如上面的++,而函数类型可以进行调用运算,就是()。

2. 匿名函数

一般的函数是需要命名然后调用的,如下例中,函数被命名为add,然后通过add()调用。

		function add(a, b) {
            return a + b;
        }

        var sum = add(1, 2);

也可以不命名,直接定义一个函数,这种方式叫做函数表达式。由于函数表达式在定义函数时没有命名,所以函数表达式是一种匿名函数

		var add = function(a, b) {
            return a + b;
        }

        var sum = add(1, 2);

以上两种方式,执行结果是同样的。

3. 自执行匿名函数

有时候我们总是想偷懒,在上面的例子中,如果我们的add函数再整个使用期间,只调用一次,那就没必要再专门弄个变量add来指向函数了。

我们可以通过自执行匿名函数,直接执行当前的函数表达式,代码如下:

	  	var sum = (function (a, b) {
            return a + b;
        })(1, 2);

这里就需要解释下了,通过括号将函数包裹起来,这样的含义就是立即调用的意思,然后后面的(1,2)就是当前调用函数的参数列表。

其实就是通过括号包裹函数表达式,实现自执行效果。

4. 小结

匿名函数是一种更加简洁,更加能体现JavaScript类型规范的函数实现语法,只要想到函数也是一种类型,就比较容易理解了。

  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员大阳

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值