javascript中: (function(){})();如何理解?

2020-04-16 21:01发布

代码如下,不理解(function(){})();这个怎么理解?[removed]var c = 10;( function() {if (c) {setTimeout(arguments.calle...

代码如下,不理解(function(){})();这个怎么理解?


[removed]
var c = 10;
( function() {
if (c) {
setTimeout(arguments.callee, 1000);
}
document.getElementById("output")[removed]=c;
c--;
})();
[removed]

3条回答
tiffany
1楼 · 2020-04-17 11:59.采纳回答

匿名函数顾名思义就是没有名字的函数,通常我们所写的函数都是这样的:


 function do(){

   // 执行代码  

 };

 // 调用

 do();

这种写法是定义了一个名为do的函数,并通过函数名称进行调用。


那如果没有名字是什么样子的啊?


function () {

   // 执行代码   

 };

这种写法在编译的时候会报错:


Uncaught SyntaxError: Unexpected token (


因为浏览器在进行语法分析的时候发现这个函数根本没法执行。


在编程语言中如果又个编码方式那这种编码方式肯定是能正常运行的,再看下面的例子:


var do = function () {  

// 执行代码 

}do();

其实这种写法就是将匿名函数复制为变量do,再通过变量名执行函数。


(function(){   // 执行代码 

  console.log("打印成功");

})();


可以先把上面的代码分几个部分:


第一部分是括号里面的匿名函数,第二部分是加上括号的匿名函数,第三部分带上最后面执行用的括号。


匿名函数在括号内部可以看成是将匿名函数当成是一个变量,再通过括号进行执行。


复制代码


(function () {   

// 执行代码 

})();

// 相当于

var do = function() {   

// 执行代码  

};

do();


其实向上面这种匿名函数的写法在很多地方都有用到,这种又叫自执行函数,像JQuery 等一些工具包都会用这种写法。


冯杰
2楼 · 2020-04-16 21:45

(function(){})();是匿名函数的写法,相当于定义一个函数并直接调用。例如,定义 var a = function(){}; 调用 a();

为什么要使用匿名函数呢?因为函数具有作用域,具备封闭的代码空间,可以使代码只在函数内生效,不影响外部代码。同时使用匿名函数,也可以减少变量的声明,减少全局污染的可能。

匿名函数还有一个写法是 void function(){}(); 效果一样

相关问题推荐

  • 回答 97
    已采纳

    Js给初学者的印象总是那么的杂而乱,相信很多初学者都在找轻松学习Js的途径。在这里给大家总结一些学习Js的经验,希望能给后来的学习者探索出一条轻松学习Js之路。Js给人那种感觉的原因多半是因为它如下的特点:A:本身知识很抽象、晦涩难懂,如:闭包、内置...

  • 回答 4

    看图:

  • 回答 18

    基本类型( 6种 ):Number ( 数值 ) String ( 字符串 )Boolean ( 布尔 ) Undefined ( 未定义 )Null ( 空 )ES6 - Symbol  ( 唯一 )

  • 回答 19

    JavaScript 使网页增加互动性,使有规律地重复的HTML文段简化,减少下载时间。JavaScript 能及时响应用户的操作,对提交表单做即时的检查,无需浪费时间交由 CGI 验证。JavaScript 的特点是无穷无尽的,只要你有创意。...

  • 回答 18

    timeoutId: 定时器IDfunc: 延迟后执行的函数code: 延迟后执行的代码字符串,不推荐使用原理类似eval()delay: 延迟的时间(单位:毫秒),默认值为0param1,param2: 向延迟函数传递而外的参数,IE9以上支持setInterval: 以固定的时间间隔重复调用一个函...

  • 回答 15

    Number类型String类型Boolean类型Undefined类型Null类型

  • 回答 14

    空格在ASCII中的值为32,空字符为0,可本人觉得不就是都是为空的吗,没有什么区别?char mychar1,mychar2;mychar1=' ';mychar2='\0';printf(mychar1=%d,mychar2=%d,mychar1,mychar2);//其中mychar1=32;mychar2=0;...

  • 回答 16

    1.变量名可以有数字0~9、大小写字母、下划线、美元符$组成。2.变量名不能以数字开头。 当我们以数字为开头时,代码就会出现橙色下划线,代表命名不...3.变量名不允许使用中文。 不能允许使用中文这个就不用多说了吧,不管你在哪找代码来看,代码中...4.区分大小写...

  • 回答 8

    向一个对象数组里面添加新的属性var arry= [{a:11,b:22,c:33,d:44},{a:11,b:0,c:0,d:44},{a:11,b:22,c:99,d:99}];var arry2=[];arry.map(((item, index)=> {arry2.push(Object.assign({},item,{mess1:item.c,mess2:item.d}))}))cons...

  • 回答 2

    我觉得getTopWindow() 应该是他自己写的函数 mask  应该是getTopWindow()函数中 return 出的一个什么玩意show()  jQuery的显示

  • 回答 16

    看上图

  • 回答 9

    如图所示

  • 回答 12

    1、原型对象也是普通的对象,是对象一个自带隐式的 __proto__ 属性,原型也有可能有自己的原型,如果一个原型对象的原型不为 null 的话,我们就称之为原型链 2、 原型链是由一些用来继承和共享属性的对象组成的(有限的)对象链...

  • js选项卡的实现原理2021-06-15 21:48
    回答 6

    如图所示,最简单的选项卡思路:选项卡就是点击按钮切换到相应内容,其实就是点击按钮把内容通过display(block none)来实现切换的。1、首先获取元素。2、for循环历遍按钮元素添加onclick 或者 onmousemove事件。3、因为点击当前按钮时会以高亮状态显示,所以...

  • 回答 4

    1、js截取两个字符串之间的内容:123var str = aaabbbcccdddeeefff; str = str.match(/aaa(\S*)fff/)[1]; alert(str);//结果bbbcccdddeee2、js截取某个字符串前面的内容:123var str = aaabbbcccdddeeefff; tr = str.match(/(\S*)fff/)[1];......

  • 回答 4

    如果是ajax 就直接获取如果是传到一个页面 就再get再在js中使用 就可以获取了。 可以在js中获取一个变量 但是不能写入一段java代码.

没有解决我的问题,去提问