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 相关文章推荐
用javascript来实现动画导航效果的代码
Dec 16 Javascript
jquery 图片预加载 自动等比例缩放插件
Dec 25 Javascript
javascript天然的迭代器
Oct 29 Javascript
node.js中的http.response.write方法使用说明
Dec 14 Javascript
JavaScript实现的一个倒计时的类
Mar 12 Javascript
使用jQuery实现WordPress中的Ctrl+Enter和@评论回复
May 21 Javascript
手机Web APP如何实现分享多平台功能
Aug 19 Javascript
AngularJS中$injector、$rootScope和$scope的概念和关联关系深入分析
Jan 19 Javascript
javascript ES6中箭头函数注意细节小结
Feb 17 Javascript
手写Vue弹窗Modal的实现代码
Sep 11 Javascript
vue 通过base64实现图片下载功能
Dec 19 Vue.js
原生js实现自定义难度的扫雷游戏
Jan 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/10/09 PHP
提升PHP执行速度全攻略(上)
2006/10/09 PHP
配置Apache2.2+PHP5+CakePHP1.2+MySQL5运行环境
2009/04/25 PHP
比较全面的PHP数组的使用方法小结
2010/09/23 PHP
php后退一页表单内容保存实现方法
2012/06/17 PHP
typecho插件编写教程(二):写一个新插件
2015/05/28 PHP
Yii2使用$this->context获取当前的Module、Controller(控制器)、Action等
2017/03/29 PHP
Laravel获取当前请求的控制器和方法以及中间件的例子
2019/10/11 PHP
js获取单选框或复选框值及操作
2012/12/18 Javascript
jQuery Deferred和Promise创建响应式应用程序详细介绍
2013/03/05 Javascript
jquery简单实现滚动条下拉DIV固定在头部不动
2013/11/25 Javascript
Jquery each方法跳出循环,并获取返回值(实例讲解)
2013/12/12 Javascript
JavaScript参数个数可变的函数举例说明
2014/10/10 Javascript
javascript框架设计之类工厂
2015/06/23 Javascript
跟我学习javascript的基本类型和引用类型
2015/11/16 Javascript
jQuery实现无限往下滚动效果代码
2016/04/16 Javascript
js实现自定义路由
2017/02/04 Javascript
Vue2.5 结合 Element UI 之 Table 和 Pagination 组件实现分页功能
2018/01/26 Javascript
Vux+Axios拦截器增加loading的问题及实现方法
2018/11/08 Javascript
[58:35]OG vs EG 2019国际邀请赛淘汰赛 胜者组 BO3 第二场 8.22
2019/09/05 DOTA
[01:10:30]DOTA2-DPC中国联赛正赛 Dragon vs Dynasty BO3 第一场 3月4日
2021/03/11 DOTA
Python读写Redis数据库操作示例
2014/03/18 Python
python实现k-means聚类算法
2018/02/23 Python
可能是最全面的 Python 字符串拼接总结【收藏】
2018/07/09 Python
Python实现网站表单提交和模板
2019/01/15 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
HTML5中的Web Notification桌面右下角通知功能的实现
2018/04/19 HTML / CSS
SmartBuyGlasses中国:唯视良品(销售名牌太阳镜、墨镜和眼镜框)
2017/07/03 全球购物
俄罗斯名牌服装网上商店:UNIQUE FABRIC
2019/07/25 全球购物
信息技术专业大学生个人的自我评价
2013/10/05 职场文书
教师求职自荐书
2014/06/14 职场文书
酒店财务部岗位职责
2015/04/14 职场文书
理想国读书笔记
2015/06/25 职场文书
怎样写好演讲稿题目?
2019/08/21 职场文书
PostgreSQL基于pgrouting的路径规划处理方法
2022/04/18 PostgreSQL
腾讯云服务器部署前后分离项目之前端部署
2022/06/28 Servers