javascript中 (function(){})();如何理解?
<p>javascript中 (function(){})();如何理解?</p><p>javascript中: (function(){})()是匿名函数,主要利用函数内的变量作用域,避免产生全局变量,影响整体页面环境,增加代码的兼容性。</p>
<p>(function(){})是一个标准的函数定义,但是没有复制给任何变量。所以是没有名字的函数,叫匿名函数。没有名字就无法像普通函数那样随时随地调用了,所以在他定义完成后就马上调用他,后面的括号()是运行这个函数的意思。</p>
<p><strong>扩展资料</strong></p>
<p>函数声明:使用function声明函数,并指定函数名。 </p>
<p>function setFn() { // coding }</p>
<p>函数表达式:使用function声明函数,但未指定函数名,将匿名函数赋予一个变量。</p>
<p>var setFn = function() { // coding}</p>
<p>匿名函数:使用function关键字声明函数,但未指定函数名。匿名函数属于函数表达式,匿名函数有很多作用,赋予一个变量则创建函数,赋予一个事件则成为事件处理程序或创建闭包等等。</p>
<p>function() { // coding}</p>
<p> </p>
<p><img src="https://img2018.cnblogs.com/blog/745723/201906/745723-20190613163416949-1422150955.png"></p>
<p>javascript中function前面加(/!/+/-/~的含义</p>
<p>自执行匿名函数 常见格式:(function(){ /* code */ })(参数);</p>
<ul>
<li>作用:可以用它创建命名空间,只要把自己的所有代码都写在这个特殊的函数包装内,那么外部就不能访问,除非你允许(变量前加上window,这样该函数后变量就成为全局)。各JavaScript库的代码也基本上是这种组织形式。</li>
<li>执行函数的作用主要为匿名和自动执行,代码在被解释时就已经在运行了。</li>
</ul>
<h1><span style="font-size: 14px; font-family: "Microsoft YaHei""> +function(){} 作用</span></h1>
<p>+function(){}();</p>
<p>这里的加号,可以替换成 ~ , * , + , - , ! 等其他一元操作符,<br>其效果相当于:<br>(function() { console.log(“Foo!”); }<span style="color: rgba(255, 102, 0, 1)">)()</span>;<br>// or<br>(function() { console.log(“Foo!”); }<span style="color: rgba(255, 102, 0, 1)">())</span>;</p>
<p>如果没有这个加号的话,解析器会认为function是一个函数声明的开始,而后面()将会导致语法错误。<br>在function前面加上+号时,就变成了一个函数表达式,而函数表达式后面又添加了一个()就变成了一个立即执行的函数了。</p><br><br>
来源:https://www.cnblogs.com/yangai/p/11017375.html
頁:
[1]