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


Posted in Javascript onMay 15, 2016

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

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

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

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

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

// 在传统写法上去掉小括号,并在前面加上运算符 ~,!,+,-
~function(){
alert('hello');
}();
!function(){
alert('hello');
}();
+function(){
alert('hello');
}();
-function(){
alert('hello');
}();

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

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

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

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

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

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

但是,有两种情况会报错

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

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

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

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

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

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

以上所述是小编给大家介绍的Javascript自执行匿名函数(function() { })()的原理浅析,希望对大家有所帮助!

Javascript 相关文章推荐
jquery 指南/入门基础
Nov 30 Javascript
javascript 短路法代码精简
Aug 20 Javascript
Jquery中增加参数与Json转换代码
Nov 20 Javascript
JavaScript 事件系统
Jul 22 Javascript
jQuery实现感应鼠标动画效果自动伸长的输入框实例
Feb 24 Javascript
jQuery ajax时间差导致的变量赋值问题分析
Jan 22 Javascript
详解webpack+gulp实现自动构建部署
Jun 29 Javascript
React组件中的this的具体使用
Feb 28 Javascript
.vue文件 加scoped 样式不起作用的解决方法
May 28 Javascript
webpack4.x开发环境配置详解
Aug 04 Javascript
vue中各选项及钩子函数执行顺序详解
Aug 25 Javascript
JS实现移动端在线签协议功能
Aug 22 Javascript
js阻止浏览器默认行为的简单实例
May 15 #Javascript
js添加绑定事件的方法
May 15 #Javascript
JavaScript绑定事件监听函数的通用方法
May 14 #Javascript
易被忽视的js事件问题总结
May 14 #Javascript
jQuery防止重复绑定事件的解决方法
May 14 #Javascript
jQuery基于扩展简单实现倒计时功能的方法
May 14 #Javascript
jquery动态切换背景图片的简单实现方法
May 14 #Javascript
You might like
第十节--抽象方法和抽象类
2006/11/16 PHP
Php Ctemplate引擎开发相关内容
2012/03/03 PHP
php中pcntl_fork创建子进程的方法实例
2019/03/14 PHP
php连接mysql数据库最简单的实现方法
2019/09/24 PHP
jquery中常用的函数和属性详细解析
2014/03/07 Javascript
js控制当再次点击按钮时的间隔时间
2014/06/03 Javascript
node.js+Ajax实现获取HTTP服务器返回数据
2014/11/26 Javascript
6种javascript显示当前系统时间代码
2015/12/01 Javascript
浅谈JS原型对象和原型链
2016/03/02 Javascript
JS组件系列之Bootstrap table表格组件神器【终结篇】
2016/05/10 Javascript
JS中精巧的自动柯里化实现方法
2017/12/12 Javascript
vue组件tabbar使用方法详解
2018/11/06 Javascript
vue2中引用及使用 better-scroll的方法详解
2018/11/15 Javascript
layui默认选中table的CheckBox复选框方法
2019/09/19 Javascript
Python中super关键字用法实例分析
2015/05/28 Python
python使用生成器实现可迭代对象
2018/03/20 Python
[原创]Python入门教程3. 列表基本操作【定义、运算、常用函数】
2018/10/30 Python
对django 模型 unique together的示例讲解
2019/08/06 Python
详解Python3定时器任务代码
2019/09/23 Python
python返回数组的索引实例
2019/11/28 Python
python opencv实现图片缺陷检测(讲解直方图以及相关系数对比法)
2020/04/07 Python
java关于string最常出现的面试题整理
2021/01/18 Python
购买瑞典当代设计的腕表和太阳眼镜:TRIWA
2016/10/30 全球购物
类如何去实现接口
2013/12/19 面试题
技校生自我鉴定范文
2013/09/26 职场文书
班组长安全职责
2014/01/05 职场文书
教学改革实施方案
2014/03/31 职场文书
安全生产大检查方案
2014/05/07 职场文书
生物技术专业求职信
2014/06/10 职场文书
拒绝黄毒毒宣传标语
2014/06/26 职场文书
公安局副政委班子个人对照检查材料
2014/10/04 职场文书
房地产公司财务总监岗位职责
2015/04/03 职场文书
大学生创业计划书
2019/06/24 职场文书
创业计划书详解
2019/07/19 职场文书
学会用Python实现滑雪小游戏,再也不用去北海道啦
2021/05/20 Python
mysql查询结果实现多列拼接查询
2022/04/03 MySQL