Javascript中匿名函数的调用方式

在使用javascript时我们经常会遇到一种在定义时不带名称的函数,即匿名函数,它的应用很广泛。这篇文档暂不讨论它用的何处,主要是讨论匿名函数的调用。匿名函数最常用的调用方式有现两种:

1 //方式1,调用函数,得到返回值。强制运算符使函数调用执行
2  (function(x,y){
3 alert(x+y);
4 return x+y;
5 }(3,4));
1 //方式二,调用函数,得到返回值。强制函数直接量执行再返回一个引用,引用再去调用执行
2  (function(x,y){
3 alert(x+y);
4 return x+y;
5 })(3,4);
6

这两种方法的执行效率是一样的,但是jslint中推荐使用方式1。

下面我们介绍不常用的方式3及其变种

1 //方式三,调用函数,忽略返回值
2   void function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

1 //变种一,调用函数
2  + function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

1 //变种一,调用函数
2  - function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

通过在匿名函数前添加运算符,达到强制匿名函数执行的效果。

有一种特别容易使人迷惑的调用匿名函数的方式:

1 //变种三,调用函数
2 var c= function(x) {
3 x = x-1;
4 alert(x);
5 }(9);

这种方式也可以调用匿名函数,这不是使用变量形式自定义函数嘛?哦,是吗,不是吧,后面还有个()呢。

关键是"="运算符的使用,哈哈,看明白了吗。

posted @ 2011-03-04 16:22  郭培  阅读(314)  评论(0编辑  收藏  举报