一聚教程网:一个值得你收藏的教程网站

最新下载

热门教程

javascript 匿名函数用法

时间:2011-06-28 编辑:简简单单 来源:一聚教程网

 函数关键字(function)语句:
      function fnMethodName(x){alert(x);}
   2. 函数字面量(Function Literals):
      var fnMethodName = function(x){alert(x);}
   3. Function()构造函数:
      var fnMethodName = new Function('x','alert(x);')

上面三种方法定义了同一个方法函数fnMethodName,第1种就是最常用的方法,后两种都是把一个函数复制给变量fnMethodName,而这个函数是没有名字的,即匿名函数。实际上,相当多的语言都有匿名函数

1、(function(){alert("hello");})()

2、无名函数

无名函数,其中一个作用可能是生成新的函数对象的引用,主要是用于定义。

另一个用处就是针对js中一些无法含参的回调函数而言的。
明显的例子就是setInterval,我想这是很多人头疼的一个函数,尤其是你想在回调函数中添加参数的时候。
而且最叫人头疼的是,DHTML不是w3c规定的标准,于是不同的浏览器给出的setInterval参数表还不一样。。。
就我测试的两款浏览器来说(IE内核,webkit内核)
IE:setInvterval(function, msecond [,lang]);
chrome:setInterval(function, msecond [, pram1, pram2, ....]);
也就是说,chrome里面是允许对function添加参数的,参数表在最后边。然而IE最后一个参数的作用是标明所用的脚本语言种类,因为IE除了js还支持vbs等其他的脚本语言。
为了解决兼容性,只好用到无名函数。。。
[code]

function test(yourArg)
{
var arg = yourArg;
setInterval(function(){callback(arg)}, time);
}


匿名函数的代码模式

昨天 hedger wang 在他的blog介绍了 几种匿名函数的代码模式:

错误模式:其无法工作,浏览器会报语法错。

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

   1. 函数字面量:首先声明一个函数对象,然后执行它。
      (function(){ alert(1); } ) ( );
   2. 优先表达式:由于Javascript执行表达式是从圆括号里面到外面,所以可以用圆括号强制执行声明的函数。
      ( function(){ alert(2); } ( ) );
   3. Void操作符:用void操作符去执行一个没有用圆括号包围的一个单独操作数。
      void function(){ alert(3); }()

这三种方式是等同的,hedger wang因为个人原因比较喜欢第3种,而在实际应用中我看到的和使用的都是第1种

热门栏目