javascript 三種數組複製方法的效能對比_javascript技巧

來源:互聯網
上載者:User

一. 三種數組複製方法
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種方法所耗掉的時間.

<!DOCTYPE html> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=GB18030" /> <title>3種數組複製方法的效能對比</title> <meta name="description" content="數組複製, slice, concat" /> <meta name="keywords" content="數組複製, slice, concat" /> </head> <body> <div class="section"> <p>我們以一個擁有500000個子項的數組, 作為測試對象(IE不會崩潰哦!).</p> <button id="J_CopyBySlice">copyBySlice</button> <button id="J_CopyByConcat">copyByConcat</button> <button id="J_CopyByLoop">copyByLoop</button> </div> <script type="text/javascript"> (function() { var arr = []; for (var i=0; i<500000; i++) { arr.push(i); } var get = function(id) { return document.getElementById(id); }; var bySlice = function() { return arr.slice(); }; var byConcat = function() { return arr.concat(); }; var byLoop = function() { var newArr = []; for (var i=0, j=arr.length; i<j; i++) { newArr.push(arr[i]); } return newArr; }; var showResult = function(way, el) { var st = +new Date(), oMsg, newArr; switch (way) { case 'slice': newArr = bySlice(); break; case 'concat': newArr = byConcat(); break; case 'split': newArr = bySplit(); break; case 'loop': newArr = byLoop(); break; } oMsg = document.createElement('p'); oMsg.innerHTML = 'copy by ' + way + ' use time: ' + (+new Date() - st) + 'ms'; el.parentNode.appendChild(oMsg); }; get('J_CopyBySlice').onclick = function() { showResult('slice', this); } get('J_CopyByConcat').onclick = function() { showResult('concat', this); } get('J_CopyByLoop').onclick = function() { showResult('loop', this); } })(); </script> </body> </html>
[Ctrl+A 全選 注:如需引入外部Js需重新整理才能執行]


四. 測試結果(點圖片可查看大圖)

五. 結論
對於IE, 使用slice; 非IE, 使用concat.
對於webkit, 使用concat; 其他瀏覽器, 使用slice.

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.