Javascript自执行匿名函数(function() { })()的原理浅析

函数是JavaScript中最灵活的一种对象,这里只是讲解其匿名函数的用途。匿名函数指没有指定函数名或指针的函数,自执行匿名函数只是其中一种,下文中称这种函数为:自执行函数

下面是一个最常见的自执行函数:

1
2
3
4
// 传统匿名函数
( function () {
alert( 'hello' );
})();

  这段代码的执行效果就是在页面再载入时弹出:"hello"

  是什么促使它自动执行的?,来看下面的代码

1
2
3
4
5
6
7
8
9
10
11
12
13
// 在传统写法上去掉小括号,并在前面加上运算符 ~,!,+,-
~ function (){
alert( 'hello' );
}();
! function (){
alert( 'hello' );
}();
+ function (){
alert( 'hello' );
}();
- function (){
alert( 'hello' );
}();

  这些写法与上文所说的传统方式执行起来并无区别,

  我发现,这些写法的共同点是运算符,其实传统方式的小括号()也属于运算的一种,出现在:a=b*(c+d),

  运算符 + 传递给自生的参数 = 函数自动执行?但有些符号也不支持,比如“=,*,/”号,它自执行的原因还是很神秘,网上也找不到像样的答案

  然后我发现了一个神奇的现象,这些运算符可以无限叠加。。。。。。

1
2
3
4
// function前面是特定符号可以无限叠加...
~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~!+-~!+-+-!~~~~~~~~+-!!!!!!+ function a(b) {
alert( 'hello' );
}();

  程序正常运行!!!!!!

  但是,有两种情况会报错

    如果连续出现三个及以上的“+”或“-”符号,则会出错;

    如果连续出现两个“+”或“-”符号再接上其他符号,则会出错,例如“++~”,“--+”;

  错误提示:Uncaught ReferenceError: Invalid left-hand side expression in prefix operation (意思是左侧表达式错误)

  然后我用同样的符号来运算一个变量,发现一模一样,这或许已经可以说明是javascript的运算促使函数的自动执行,也可以理解为通过运算来调用这个函数!

  并不是函数自己执行了,而是通过运算来调用这个函数!,但只支持部分运算方式!

  此外,这个自执行函数,未必是匿名函数!看上方的代码,我在运算符后的函数中,定义了函数名称a,并没有什么异常,但也没什么卵用- -!,这个a依然无法被其他方法调用,但我觉得很多人都称其为匿名函数有点不妥!

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值