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

mracalele      2022-02-07     324

关键词:

匿名函数就是没有函数名的函数。这篇文章主要介绍了Javascript自执行匿名函数(function() { })()的原理浅析的相关资料,需要的朋友可以参考下

函数是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中最灵活的一种对象,这里只是讲解其匿名函数的用途。匿名函数:就是没有函数名的函数。 函数的定义,大致可分为三种方式:第一种:这也是最常规的一种123functiondouble(x){       re... 查看详情

js基础之javascript函数定义及种类-普通涵数-自执行函数-匿名函数

普通函数1、不带参数functionfucname(){alert("hello");}funcname()2、带参数functionfuncname(arg){alert("hello");}funcname("Brin") 普通函数,自执行函数1、不带参数(function(){alert(123);})()2、带参数(function(arg){alert(123);})("Bri 查看详情

javascript的匿名函数与自执行

 第一种:这也是最常规的一种123functiondouble(x){       return2*x;      }第二种:这种方法使用了Function构造函数,把参数列表和函数体都作为字符串,很不方便,不建议使用。1vardoub... 查看详情

自执行函数

javascript中为何在匿名function函数后面还外加一个括号?(function(){...}())或(function(){...})()名词解释:“匿名函数自执行”定义一个匿名函数,然后马上调用它(因为它是匿名的,如果不立即调用就获取不到该函数的引用了)。通常... 查看详情

匿名自执行函数报错

 js报错(intermediatevalue)(...)isnotafunction2017-02-1817:49 1497人阅读 评论(0) 收藏 举报[javascript] viewplain copy  //通过函数构造器定义  function beverage_tr 查看详情

js中的匿名函数和匿名自执行函数(代码片段)

1.匿名函数的常见场景js中的匿名函数是一种很常见的函数类型,比较常见的场景:<inputtype="button"value="点击"id="btn"> <scripttype="text/javascript"> //匿名函数的第一种情形 varbtn 查看详情

javascript-函数

...用到。 二:匿名函数  匿名函数就是没有函数名,JavaScript函数可以通过一个表达式定义  varx=f 查看详情

javascript函数:匿名但有名字? [复制]

】javascript函数:匿名但有名字?[复制]【英文标题】:functionjavascript:anonymousbutwithaname?[duplicate]【发布时间】:2012-04-0403:58:40【问题描述】:可能重复:“Usual”functionsvsfunctionvariablesinJavaScriptwhatsthedifferencebetweenfunctionfoo()andfoo=funct... 查看详情

(转)扫盲--javascript的立即执行函数

看过jQuery源码的人应该知道,jQuery开篇用的就是立即执行函数。立即执行函数常用于第三方库,好处在于隔离作用域,任何一个第三方库都会存在大量的变量和函数,为了避免变量污染(命名冲突),开发者们想到的解决办法就... 查看详情

javascript中的自执行函数

学习es6的时候遇到了自执行函数,感觉有必要写下来,一方面加深自己的记忆,另一方面还能分享给大家。什么是自执行函数?自执行函数就是为了不污染全局变量命名空间的一中匿名函数,相当于自己创建了一个作用域,下面... 查看详情

js中(function(){…})()立即执行函数写法理解

(function(){…})()和(function(){…}())是两种javascript立即执行函数的常见写法,最初我以为是一个括号包裹匿名函数,再在后面加个括号调用函数,最后达到函数定义后立即执行的目的,后来发现加括号的原因并非如此。要理... 查看详情

自执行匿名函数

自执行匿名函数:常见格式:(function(){/*code*/})();解释:包围函数(function(){})的第一对括号向脚本返回未命名的函数,随后一对空括号立即执行返回的未命名函数,括号内为匿名函数的参数。作用:可以用它创建命名空间,只要... 查看详情

javascript匿名函数和闭包

//1匿名函数的定义与使用//1.1把匿名函数赋值给变量通过变量执行varbox=function(){return"Lee";}box();//"Lee"//1.2通过自我执行来执行匿名函数//(匿名函数)();(function(){return"Lee";})();//"Lee"//1.3匿名函数自我传参(function(age){returnage;})(100);//100//2... 查看详情

javascript自执行函数和jquery扩展方法

  我们通常将JS代码写在一个单独的JS文件中,然后在页面中引入该文件。但是,有时候引入后会碰到变量名或函数名与其它JS代码通途的问题。那么如何解决这个问题呢?作用域隔离。在JS中,作用域是通过函数来划分的,将J... 查看详情

自执行匿名函数格式

(function()/**code*/)() 上面写法是函数声明..下面写法是转变成函数表达式(function()/*code*/())!function()/*code*/()~function()/*code*/()-function()/*code*/()+function()/*code*/() 查看详情

匿名函数自执行(代码片段)

(function()());(function())();[function()()]; ~function()();!function()();+function()();-function()(); deletefunction()();typeoffunction()();voidfunction()();newfunction( 查看详情

javascript匿名函数与闭包

匿名函数是相对于有名字的函数如functionsetAge(){}函数名为setAge而类似于function(){}则就是一个匿名函数有名字的函数执行时可以写成setAge(),而没有名字的函数则执行要写成(function())();另一种方式是把匿名函数赋值给一个变量来使用... 查看详情

javascript自定义函数进阶(匿名函数变量的作用域)(代码片段)

...,这一类函数也被称为拉姆达函数,是一种使用JavaScript函数的强大方式,匿名函数有两种语法形式:语法一:(function(形式参数列表)  语句 )(实际参数列表); 例 查看详情