微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

深入浅析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、该函数的作用主要为 匿名 和 自动执行

原文地址:https://www.jb51.cc/js/47367.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐