Array.prototype.concat不是通用方法反驳[译]

时间:2024-05-25 15:19:13 

ECMAScript 5.1规范§15.4.4.4 中说到:


concat函数是有意设计成通用的;它并不要求它的this值必须得是个Array对象.因此,它可以被转移到其它类型的对象上作为方法来调用.



本文中的代码都使用了[]来作为Array.prototype的快捷方式.这已经是很常用的技巧了,虽然可读性差点:你通过一个对象实例访问到了Array.prototype上的方法.但是,这样的访问方式在现代的JavaScript引擎中非常之快,以至于我怀疑,说不定在这种调用方式下,这些JavaScript引擎可能已经不再创建数组实例了.本文中所有的例子都在Firefox和V8中尝试运行过.

让我们看一下concat到底是不是个通用方法:如果它是一个通用方法,则不管this的值是一个真实数组还是个类数组对象(拥有length属性,能通过索引访问每个元素),方法的返回结果都应该是一样的.我们首先尝试在数组上调用concat方法:


> ["hello"].concat(["world"])
["hello", "world"]

> [].concat.call(["hello"], ["world"]) // 和上面的一样
["hello", "world"]



然后,我们使用一个类数组对象来进行上面的连接操作.结果应该是一样的.


> [].concat.call({ 0: "hello", length: 1 }, ["world"])
[ { '0': 'hello', length: 1 }, 'world' ]


特殊变量arguments也是一个类数组对象.结果仍然不是我们所期望的:


> function f() { return [].concat.call(arguments, ["world"]) }
> f("hello")
[ { '0': 'hello' }, 'world' ]



真正的通用方法应该是这样的Array.prototype.push:


> var arrayLike = { 0: "hello", length: 1 };
> [].push.call(arrayLike, "world")
2
> arrayLike
{ '0': 'hello', '1': 'world', length: 2 }



译者注:浏览器只是按照标准来实现,所以并不存在bug的问题.

标签:Array,prototype
0
投稿

猜你喜欢

  • Python简单实现词云图代码及步骤解析

    2021-05-13 00:25:52
  • Python代码块批量添加Tab缩进的方法

    2022-10-10 16:41:39
  • Python实现求数列和的方法示例

    2021-07-15 05:27:08
  • springboot多数据源配合docker部署mysql主从实现读写分离效果

    2024-01-28 11:14:53
  • Python调用钉钉自定义机器人的实现

    2023-08-29 20:08:55
  • Python函数进阶之迭代器的原理与使用详解

    2023-03-28 09:02:01
  • python实现ip地址查询经纬度定位详解

    2021-09-13 08:01:52
  • python字典快速保存于读取的方法

    2022-02-18 02:22:11
  • 查看ASP详细错误提示信息的图文设置方法

    2011-02-05 11:02:00
  • JavaScript的replace方法与正则表达式结合应用讲解

    2008-03-06 21:37:00
  • Python HTMLParser模块解析html获取url实例

    2023-08-18 01:09:47
  • vue 封装面包屑组件教程

    2024-05-02 17:11:11
  • 网页模式化窗口

    2008-04-27 20:52:00
  • 写好Python代码的几条重要技巧

    2021-09-16 21:49:47
  • php 无法载入mysql扩展

    2023-09-07 13:07:40
  • 基于Python计算圆周率pi代码实例

    2021-03-06 05:13:17
  • mysql 8.0.27 安装配置方法图文教程(Windows64位)

    2024-01-19 07:37:59
  • python绘图模块之利用turtle画图

    2022-08-13 01:17:19
  • vue中的数据绑定原理的实现

    2024-05-05 09:09:34
  • Mysql到Elasticsearch高效实时同步Debezium实现

    2024-01-25 15:22:46
  • asp之家 网络编程 m.aspxhome.com