html5中文学习网

您的位置: 首页 > 网站及特效实例 > javascript特效 » 正文

深入浅析JavaScript函数前面的加号和叹号_javascript技巧_

[ ] 已经帮助:人解决问题

H99HTML5中文学习网 - HTML5先行者学习网

+function(){}(); 

这里的加号,也可以替换成!,~等其他一元操作符,其效果相当于:H99HTML5中文学习网 - HTML5先行者学习网

(function() { console.log("Foo!"); })(); // or (function() { console.log("Foo!"); }()); 

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

下面看下js函数前面感叹号的作用:H99HTML5中文学习网 - HTML5先行者学习网

一、JS函数声明形式H99HTML5中文学习网 - HTML5先行者学习网

function fnA(){alert('msg');} //声明式定义函数 

二、JS函数表达式形式H99HTML5中文学习网 - HTML5先行者学习网

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

三、JS匿名函数声明完立即执行的常见格式H99HTML5中文学习网 - HTML5先行者学习网

(function() { /* code */ })();

说明H99HTML5中文学习网 - HTML5先行者学习网

1、包围函数(function(){})的第一对括号向脚本返回未命名的函数,随后一对空括号立即执行返回的未命名函数,括号内为匿名函数的参数。H99HTML5中文学习网 - HTML5先行者学习网

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

3、该函数的作用主要为 匿名 和 自动执行H99HTML5中文学习网 - HTML5先行者学习网

(责任编辑:)
推荐书籍
推荐资讯
关于HTML5先行者 - 联系我们 - 广告服务 - 友情链接 - 网站地图 - 版权声明 - 人才招聘 - 帮助