JavaScript 批量創(chuàng)建數(shù)組的方法
JavaScript有許多批量創(chuàng)建數(shù)組的方法,為了衡量它們的性能,我分別使用不同的方法創(chuàng)建一個長度為100000的數(shù)組,且鍵和值相等。同時,我定義了下面這個函數(shù)用來測量創(chuàng)建數(shù)組所耗費的時間:
function t(fn) {
var start = Date.now();
fn.call(this);
var end = Date.now();
return (end - start) + 'ms';
}
以下為常用的幾個創(chuàng)建數(shù)組的方法以及它們所耗費的時間:
使用join和split

該方法把大量時間耗費在了map操作上,去掉map后只需要2ms

使用apply

這里用到了一個{ length: 100000 }偽數(shù)組,NodeList和arguments都是偽數(shù)組(array-like object),它們都不是真正意義上的數(shù)組,而是帶有"length屬性"并且同時具備"索引屬性"的對象,不能直接使用數(shù)組的那些方法,而apply和call卻可以接受這種偽數(shù)組。我們平時在用的Array.prototype.slice( arguments)就是基于這個原理。
這里把長度為100000的偽數(shù)組傳遞給Array函數(shù),構(gòu)造出了一個長度為100000的數(shù)組,然后再用map賦值。有同學(xué)可能要問了,為什么不直接Array(100000)生成數(shù)組,這是因為通過Array(100000)生成的數(shù)組每個值都為undefined,無法通過map遍歷。
使用Array.from()
這是ES6新出的方法,可以將偽數(shù)組直接轉(zhuǎn)換為數(shù)組

如果把偽數(shù)組換成數(shù)組,速度下降了很多。

使用Array.fill()
先用Array.fill()填充數(shù)組,之后再通過map依個賦值

使用for循環(huán)

我表示當(dāng)時就驚呆了,還一直在檢查是不是少打個0. 我表示不服,想用push試一下

發(fā)現(xiàn)push也好快哦……
比較下來,發(fā)現(xiàn)還是最原始的for循環(huán)直接賦值的速度最快,其他幾個方法速度都差不多。
但for循環(huán)寫起來實在麻煩,一句話就能搞定的事需要三句才能搞定。
所以,如果對性能沒有太大要求的話(畢竟在實際開發(fā)中也不會有100000那么大的數(shù)組),使用apply和Array.from最方便。
以上所述是小編給大家介紹的JavaScript 批量創(chuàng)建數(shù)組的方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
uni-app微信小程序使用echarts的詳細(xì)圖文教程
為了兼容小程序Canvas,ECharts提供了一個小程序的組件,用這種方式可以方便地使用ECharts,下面這篇文章主要給大家介紹了關(guān)于uni-app微信小程序使用echarts的相關(guān)資料,需要的朋友可以參考下2022-10-10
JS鼠標(biāo)3次點擊事件實現(xiàn)代碼及擴展思路
這篇文章主要介紹了JS鼠標(biāo)3次點擊事件實現(xiàn)及擴展思路,需要的朋友可以參考下2017-09-09
每天一篇javascript學(xué)習(xí)小結(jié)(Boolean對象)
這篇文章主要介紹了javascript中的Boolean對象知識點,對Boolean對象的基本使用方法進行解釋,一段很詳細(xì)的代碼介紹,感興趣的小伙伴們可以參考一下2015-11-11
JavaScript字符串_動力節(jié)點Java學(xué)院整理
JavaScript中的字符串就是用''或""括起來的字符表示。下面通過本文給大家介紹JavaScript字符串的相關(guān)知識,感興趣的朋友一起看看吧2017-06-06
js將json格式的對象拼接成復(fù)雜的url參數(shù)方法
下面小編就為大家?guī)硪黄猨s將json格式的對象拼接成復(fù)雜的url參數(shù)方法。小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-05-05

