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 相关文章推荐
利用jq让你的div居中的好方法分享
Nov 21 Javascript
JavaScript执行顺序详细介绍
Dec 04 Javascript
IE6下javasc#ipt:void(0) 无效的解决方法
Dec 23 Javascript
JavaScript实现的购物车效果可以运用在好多地方
May 09 Javascript
jQuery选择器源码解读(六):Sizzle选择器匹配逻辑分析
Mar 31 Javascript
详解jquery easyui之datagrid使用参考
Dec 05 Javascript
angular学习之ngRoute路由机制
Apr 12 Javascript
使用vue-router完成简单导航功能【推荐】
Jun 28 Javascript
JavaScript创建对象方式总结【工厂模式、构造函数模式、原型模式等】
Dec 19 Javascript
浅谈Vue.js 关于页面加载完成后执行一个方法的问题
Apr 01 Javascript
JavaScript使用ul中li标签实现删除效果
Apr 15 Javascript
vue表单验证之禁止input输入框输入空格
Dec 03 Vue.js
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
推荐5款跨平台的PHP编辑器
2014/12/25 PHP
php从数据库查询结果生成树形列表的方法
2015/04/17 PHP
javascript使用onclick事件改变选中行的颜色
2013/12/30 Javascript
JS 日期比较大小的简单实例
2014/01/13 Javascript
现如今最流行的JavaScript代码规范
2014/03/08 Javascript
javascript回车完美实现tab切换功能
2014/03/13 Javascript
JavaScript生成的动态下雨背景效果实现方法
2015/02/25 Javascript
jQuery点击改变class并toggle及toggleClass()方法定义用法
2015/12/11 Javascript
JavaScript统计字符串中每个字符出现次数完整实例
2016/01/28 Javascript
轮播图组件js代码
2016/08/08 Javascript
JS轮播图中缓动函数的封装
2020/11/25 Javascript
深入理解Node.js中的进程管理
2017/03/13 Javascript
基于js中style.width与offsetWidth的区别(详解)
2017/11/12 Javascript
jQuery实现简单复制json对象和json对象集合操作示例
2018/07/09 jQuery
详解如何运行vue项目
2019/04/15 Javascript
layui--js控制switch的切换方法
2019/09/03 Javascript
[01:38]【DOTA2亚洲邀请赛】Sumail——梦开始的地方
2017/03/03 DOTA
python刷投票的脚本实现代码
2014/11/08 Python
Python中http请求方法库汇总
2016/01/06 Python
python中使用iterrows()对dataframe进行遍历的实例
2018/06/09 Python
python实现桌面壁纸切换功能
2019/01/21 Python
python禁用键鼠与提权代码实例
2019/08/16 Python
伊利莎白雅顿官网:Elizabeth Arden
2016/10/10 全球购物
澳大利亚体育和露营装备在线/实体零售商:Find Sports
2020/06/03 全球购物
Java中实现多态的机制
2015/08/09 面试题
十一个高级MySql面试题
2014/10/06 面试题
网页美工求职信
2014/02/15 职场文书
数学高效课堂实施方案
2014/03/29 职场文书
毕业生欢送会主持词
2014/03/31 职场文书
法制宣传标语
2014/06/23 职场文书
社团活动总结格式
2014/08/29 职场文书
我们的节日中秋节活动总结
2015/03/23 职场文书
员工离职通知函
2015/04/25 职场文书
节约用电倡议书
2015/04/28 职场文书
Python游戏开发实例之graphics实现AI五子棋
2021/11/01 Python
winserver2019安装软件一直卡在应用程序正在为首次使用做准备
2022/06/10 Servers