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

作者:怿飞 来源:怿飞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
投稿

猜你喜欢

  • python利用datetime模块计算程序运行时间问题

    2022-05-24 03:13:41
  • Node.js模块全局安装路径配置方法

    2024-05-13 09:28:11
  • ASP+JAVAScript:复杂表单的动态生成与验证

    2007-10-06 21:51:00
  • Navicat数据存放位置和备份数据库路径设置方式

    2024-01-16 14:32:53
  • python使用Matplotlib改变坐标轴的默认位置

    2021-08-06 00:27:42
  • TensorFlow实现随机训练和批量训练的方法

    2022-06-07 07:45:29
  • python3实现猜数字游戏

    2022-09-11 16:10:38
  • 在django模板中实现超链接配置

    2023-03-03 12:22:44
  • 对PyQt5中树结构的实现方法详解

    2021-02-07 16:19:20
  • GO项目配置与使用的方法步骤

    2024-05-22 17:45:57
  • 详解nuxt路由鉴权(express模板)

    2024-05-11 10:22:53
  • 使用Python实现毫秒级抢单功能

    2022-10-17 18:46:16
  • 微信小程序地图(map)组件点击(tap)获取经纬度的方法

    2023-09-03 21:33:37
  • python爬虫(入门教程、视频教程) <font color=red>原创</font>

    2021-10-28 22:04:08
  • 通过SQL Server的位运算功能巧妙解决多选查询方法

    2024-01-22 01:21:26
  • Django 内置权限扩展案例详解

    2022-08-21 23:25:45
  • python基础教程之获取本机ip数据包示例

    2022-09-28 13:31:45
  • 解决flask接口返回的内容中文乱码的问题

    2022-12-17 03:00:37
  • python 实现图片裁剪小工具

    2022-04-27 18:15:15
  • python使用pygame实现笑脸乒乓球弹珠球游戏

    2021-07-26 09:49:47
  • asp之家 网络编程 m.aspxhome.com