javascript 三种数组复制方法的性能对比

2019-12-25,,,

一. 三种数组复制方法
1. by slice
var arr = [1, 2, 3], copyArr;
copyArr = arr.slice();

2. by concat
var arr = [1, 2, 3], copyArr;
copyArr = arr.concat();
3. by loop
var arr = [1, 2, 3], copyArr = [];
for (var i=0, j=arr.length; i
二. 测试环境
浏览器: IE6+, FF 3.5.5, Opera 10, Chrome 4.0.249, Safari 4.0.3

三. 测试用例
用上面3种方法, 对一个拥有500000项的数组进行复制操作, 然后对比3种方法所耗掉的时间.

[Ctrl+A 全选 注:如需引入外部Js需刷新才能执行]

四. 测试结果(点图片可查看大图)

五. 结论
对于IE, 使用slice; 非IE, 使用concat.
对于webkit, 使用concat; 其他浏览器, 使用slice.

您可能感兴趣的文章:

  • jQuery中json对象的复制方式介绍(数组及对象)
  • JavaScript数组复制详解
  • JavaScript 数组的深度复制解析
  • Javascript 复制数组实现代码
  • javascript复制对象使用说明
  • js中如何复制一个对象并获取其所有属性和属性对应的值
  • 原生js实现复制对象、扩展对象 类似jquery中的extend()方法
  • 深入理解JavaScript中的对象复制(Object Clone)
  • 改进版通过Json对象实现深复制的方法
  • JavaScript数组和对象的复制

《javascript 三种数组复制方法的性能对比.doc》

下载本文的Word格式文档,以方便收藏与打印。