如何将函数的实际参数转换成数组

作者:怿飞 来源:怿飞blog 时间:2010-01-11 19:59:00 

实际参数在函数中我们可以使用 arguments 对象获得 (注:形参可通过 arguments.callee 获得),虽然 arguments 对象与数组形似,但仍不是真正意义上的数组。

值得庆幸的是,我们可以通过数组的 slice 方法将 arguments 对象转换成真正的数组:

var args = Array.prototype.slice.call(arguments);

对于slice 方法,ECMAScript 262 中 15.4.4.10 Array.prototype.slice (start, end) 章节有备注:

The slice function is intentionally generic; it does not require that its this value be an Array object. Therefore it can be transferred to other kinds of objects for use as a method. Whether the slice function can be applied successfully to a host object is implementation-dependent.

《Pro JavaScript Design Patterns》(《JavaScript 设计模式》)的作者 Dustin Diaz 曾指出:

instead of…
var args = Array.prototype.slice.call(arguments); // 怿飞注:下称方法一
do this…
var args = [].slice.call(arguments, 0); // 怿飞注:下称方法二

但二者的性能差异真的存在吗?经过个人简单测试发现:

arguments.length 较小的时候,方法二性能上稍有一点点优势,而在arguments.length 较大的时候,方法一却又稍有优势。

最后附上方法三,最老土的方式:

var args = [];
for (var i = 1; i < arguments.length; i++) {
    args.push(arguments[i]);
}

不过对于平常来说,个人建议还是使用第二种方法,但任何解决方案,没有最好的,只有最合适:

var args = [].slice.call(arguments, 0);

理由有二:

  1. 一般的函数的 arguments.length 都在 10 以内,方法二有优势;

  2. 方法二的代码量上也比第一种少,至少可以减小一点字节 ^^

------------------------------------------------------------------

如何将 NodeList (比如:document.getElementsByTagName('div'))转换成数组呢?

解决方案简单如下:

function nodeListToArray(nodes){
    var arr, length;

    try {
        // works in every browser except IE
        arr = [].slice.call(nodes);
        return arr;
    } catch(err){
        // slower, but works in IE
        arr = [];
        length = nodes.length;

        for(var i = 0; i < length; i++){
             arr.push(nodes[i]);
         }  

        return arr;
    }
}

为什么 IE 中 NodeList 不可以使用 [].slice.call(nodes) 方法转换呢?

In Internet Explorer it throws an error that it can't run Array.prototype.slice.call(nodes) because a DOM NodeList is not a JavaScript object.

标签:函数,参数,数组
0
投稿

猜你喜欢

  • 删除数组中重复项(uniq)

    2009-12-28 12:23:00
  • 在js中调用asp页面的方法

    2007-08-21 20:30:00
  • ASP写的汉字转换为UTF-8的一段代码

    2009-07-05 18:49:00
  • 百度百科中的asp词条:什么是asp

    2008-10-11 14:38:00
  • 如何实现网上站点维护?

    2010-05-24 18:35:00
  • js高亮关键词系列方法

    2008-01-22 11:11:00
  • z-index在IE中的迷惑

    2007-05-11 16:50:00
  • IE下中英文字体不能对齐原因及解决

    2008-08-11 12:47:00
  • HTML 标签是否匹配检测代码

    2010-03-17 20:50:00
  • 安装MySQL的步骤和方法

    2009-07-30 08:38:00
  • 数据库备份过程中经常遇到的九种情况

    2008-12-26 16:38:00
  • 在ASP中使用SQL语句之12:连接

    2009-04-23 18:27:00
  • 使用实例管理器轻松管理多个MySQL实例

    2009-03-25 17:07:00
  • 正则表达式语法速查

    2007-11-11 10:43:00
  • ASP使用FSO组件生成HTML静态页面

    2007-10-15 12:19:00
  • Sql Server 2000内存调整

    2010-04-25 11:24:00
  • 减少新开窗口提升可访问性

    2009-04-17 13:56:00
  • 妙用Dreamweaver MX共享WPS Office文件

    2010-09-05 21:18:00
  • Favicon图标小常识

    2010-04-01 12:01:00
  • Oracle SQL性能优化系列学习二

    2010-07-23 13:23:00
  • asp之家 网络编程 m.aspxhome.com