深入浅析JavaScript函数前面的加号和叹号

<div class="jb51code">
<pre class="brush:js;">
+function(){}();

这里的加号,也可以替换成!,~等其他一元操作符,其效果相当于:

rush:js;"> (function() { console.log("Foo!"); })(); // or (function() { console.log("Foo!"); }());

如果没有这个加号的话,解析器会认为function是一个函数声明的开始,而后面()将会导致语法错误。在function前面加上+号时,就变成了一个函数表达式,而函数表达式后面又添加一个()就变成了一个立即执行的函数了。

下面看下js函数前面感叹号的作用:

一、JS函数声明形式

rush:js;"> function fnA(){alert('msg');} //声明式定义函数

二、JS函数表达式形式

rush:js;"> var func = function(agr1,arg2){ //创建匿名函数 alert(arg1 + ' ' + arg2); }

三、JS匿名函数声明完立即执行的常见格式

rush:js;"> (function() { /* code */ })();

说明

1、包围函数(function(){})的第一对括号向脚本返回未命名的函数,随后一对空括号立即执行返回的未命名函数,括号内为匿名函数的参数。

2、使用括号包裹定义函数体,解析器将会以函数表达式的方式去调用定义函数。也就是说,任何能将函数变成一个函数表达式的作法,都可以使解析器正确的调用定义函数。而 ! 就是其中一个,而 + - || 都有这样的功能

3、该函数的作用主要为 匿名 和 自动执行

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...