直观理解js自执行函数

要在函数体后面加括号就能立即调用,则这个函数必须是函数表达式,不能是函数声明


Jslint推荐的写法:

(function(){alert(1);}()); 

针对函数声明,使用()、!、+、-、=、void等运算符可将其转换为函数表达式:

(function(a){
    console.log(a);   //firebug输出1,使用()运算符
})(1);

(function(a){
    console.log(a);   //firebug输出2,使用()运算符
}(2));
 
!function(a){
    console.log(a);   //firebug输出3,使用!运算符
}(3);

+function(a){
    console.log(a);   //firebug输出4,使用+运算符
}(4);

-function(a){
    console.log(a);   //firebug输出5,使用-运算符
}(5);

var fn=function(a){
    console.log(a);   //firebug输出6,使用=运算符
}(6);

void function(a){
  console.log(a);    //firebug输出7,使用void运算符
}(7); 

1比2少了整体性。另外3,6,7也比较常用。

虽然匿名函数属于函数表达式,但js引擎会将开头的function关键字当做函数声明。使用上述方法可解决。

参考:

http://www.jb51.net/article/31078.htm

http://dengo.org/archives/1004

原文地址:https://www.cnblogs.com/xulei1992/p/5652654.html