欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript數(shù)組合并的多種方法

 更新時間:2016年05月22日 13:46:02   投稿:lijiao  
這篇文章主要為大家詳細介紹了JavaScript數(shù)組合并的多種方法,感興趣的朋友可以參考一下

這是一篇簡單的文章,關(guān)于JavaScript數(shù)組使用的一些技巧。我們將使用不同的方法結(jié)合/合并兩個JS數(shù)組,以及討論每個方法的優(yōu)點/缺點。

讓我們先考慮下面這情況:

var a = [ 1, 2, 3, 4, 5, 6, 7, 8, 9 ];
var b = [ "foo", "bar", "baz", "bam", "bun", "fun" ];

很顯然最簡單的結(jié)合結(jié)果應該是:

[
  1, 2, 3, 4, 5, 6, 7, 8, 9,
  "foo", "bar", "baz", "bam" "bun", "fun"
]

concat(..)

這是最常見的做法:

var c = a.concat( b );
a; // [1,2,3,4,5,6,7,8,9]
b; // ["foo","bar","baz","bam","bun","fun"]
c; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

正如你所看到的,C是一個全新的數(shù)組,表示a和b兩個數(shù)組的組合,并讓A和B不變。簡單吧?

但如果a有10,000個元素,而b也有一萬個元素? C就會有2萬個元素,所以a和b的內(nèi)內(nèi)存使用就會翻倍。

“沒問題!”,你說。讓它們被垃圾回收,把A和B設(shè)置為null,問題解決了!

a = b = null; // 'a'和'b'就被回收了
呵呵。對于只有幾個元素的小數(shù)組,這沒啥問題。但對于大數(shù)組,或者在內(nèi)存有限的系統(tǒng)中需要經(jīng)常重復這個過程,它其實還有很多改進的地方。

循環(huán)插入

好吧,讓我們將一個數(shù)組的內(nèi)容復制到另一個,使用: Array#push(..)

// `b` onto `a`
for (var i=0; i < b.length; i++) {
  a.push( b[i] );
}
a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]
b = null;

現(xiàn)在,數(shù)組a有了數(shù)組b的內(nèi)容。

似乎有更好的內(nèi)存占用。

但如果a數(shù)組比較???出于內(nèi)存和速度的原因,你可能要把更小的a放到b的前面,。沒問題,只需將push(..)換成unshift(..)即可:

// `a` into `b`:
for (var i=a.length-1; i >= 0; i--) {
  b.unshift( a[i] );
}
b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

功能技巧

不過for循環(huán)確實比較丑,而且不好維護。我們可以做的更好嗎?

這是我們的第一次嘗試,使用Array#reduce:

// `b` onto `a`:
a = b.reduce( function(coll,item){
  coll.push( item );
  return coll;
}, a );

a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

// or `a` into `b`:
b = a.reduceRight( function(coll,item){
  coll.unshift( item );
  return coll;
}, b );

b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

Array#reduce(..) Array#reduceRight(..)是不錯的,但他們是一點點笨拙。 ES6=>的箭頭函數(shù)將減少一些代碼量,但它仍然需要一個函數(shù),每個元素都需要調(diào)用一次,不是很完美。

那這個怎么樣:

// `b` onto `a`:
a.push.apply( a, b );
a; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]
// or `a` into `b`:
b.unshift.apply( b, a );
b; // [1,2,3,4,5,6,7,8,9,"foo","bar","baz","bam","bun","fun"]

這是一個要好很多吧?特別是因為 unshift(..)方法在這里并不需要擔心前面的反向排序。 ES6的spead操作會更漂亮: a.push( …b ) 或 b.unshift( …a

數(shù)組最大長度限制

第一個主要的問題是,內(nèi)存使用量增長了一倍(當然只是暫時的?。┍蛔芳觾?nèi)容基本上是通過函數(shù)調(diào)用將元素復制到堆棧中。此外,不同的JS引擎都有拷貝數(shù)據(jù)長度的限制。

所以,如果數(shù)組有一百萬個元素,你肯定會超出了push(…)或unshift(…)允許調(diào)用堆棧的限制。唉,處理幾千個元素它會做得很好,但你必須要小心,不能超過合理的長度限值。

注意: 你可以嘗試一下splice(…),它跟push(…)和unshift(…)一樣都有這種問題。

有一種方法可以避免這種最大長度限制。

function combineInto(a,b) {
  var len = a.length;
  for (var i=0; i < len; i=i+5000) {
    b.unshift.apply( b, a.slice( i, i+5000 ) );
  }
}

等一下,我們的可讀性倒退了。 就這樣吧,可能會越改越差。

以上就是本文的全部內(nèi)容,希望對大家學習javascript程序設(shè)計有所幫助。

相關(guān)文章

  • web打印小結(jié)

    web打印小結(jié)

    本文主要介紹了一款比較強大的web打印工具lodop實現(xiàn)將winform客戶端的打印,移到網(wǎng)頁上由客戶自行打印,打印要求是根據(jù)一定的格式實現(xiàn)套打的過程與方法。具有一定的參考價值,下面跟著小編一起來看下吧
    2017-01-01
  • javascript實現(xiàn)簡單的省市區(qū)三級聯(lián)動

    javascript實現(xiàn)簡單的省市區(qū)三級聯(lián)動

    本文給大家反映的是javascript實現(xiàn)的簡單的省市區(qū)三級聯(lián)動特效,不需要訪問后臺服務(wù)器端,不使用Ajax,無刷新,純JS實現(xiàn)的省市區(qū)三級聯(lián)動。當省市區(qū)數(shù)據(jù)變動是只需調(diào)正js即可。
    2015-05-05
  • JavaScript極簡入門教程(三):數(shù)組

    JavaScript極簡入門教程(三):數(shù)組

    這篇文章主要介紹了JavaScript極簡入門教程(二):數(shù)組,本文主要講解了數(shù)組的創(chuàng)建和length屬性的介紹,其它方法屬性都沒有介紹,需要的朋友可以參考下
    2014-10-10
  • 用js寫“算24”游戲的思路分析與實現(xiàn)代碼

    用js寫“算24”游戲的思路分析與實現(xiàn)代碼

    “算24”是一種游戲,小時候玩過,就是一副撲克,把大王,小王除掉,A算1點J,Q,K都算10點。任意抽4個牌,可以運用+-*/()來進行運算,把最后結(jié)果等于24。
    2008-05-05
  • 基于JavaScript實現(xiàn)圖片連播和聯(lián)級菜單實例代碼

    基于JavaScript實現(xiàn)圖片連播和聯(lián)級菜單實例代碼

    這篇文章主要介紹了基于JavaScript實現(xiàn)圖片連播和聯(lián)級菜單實例代碼,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-07-07
  • bootstrap table 多選框分頁保留示例代碼

    bootstrap table 多選框分頁保留示例代碼

    在使用bootstrap table的復選框功能的時候,由于采用服務(wù)端分頁,當在第一頁選擇了某些數(shù)據(jù),然后點擊第二頁選擇一些數(shù)據(jù),再次點回第一頁,發(fā)現(xiàn)原先選擇的數(shù)據(jù)已經(jīng)清空了,原來的多選框并不支持翻頁保留多選數(shù)據(jù),怎么解決呢,下面小編給大家分享下解決思路
    2017-03-03
  • 詳解webpack打包第三方類庫的正確姿勢

    詳解webpack打包第三方類庫的正確姿勢

    這篇文章主要介紹了詳解webpack打包第三方類庫的正確姿,我們主要介紹了webpack.optimize.CommonsChunkPlu,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-10-10
  • JSON+JavaScript處理JSON的簡單例子

    JSON+JavaScript處理JSON的簡單例子

    JSON+JavaScript處理JSON的簡單例子,需要的朋友可以參考一下
    2013-03-03
  • Leaflet 基礎(chǔ)入門教程示例

    Leaflet 基礎(chǔ)入門教程示例

    這篇文章主要為大家介紹了Leaflet 基礎(chǔ)入門教程示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-01-01
  • JavaScript中iframe實現(xiàn)局部刷新的幾種方法匯總

    JavaScript中iframe實現(xiàn)局部刷新的幾種方法匯總

    Iframe是一種嵌入網(wǎng)頁的框架形式,Web頁面可以通過更改嵌入的部分,達到部分內(nèi)容刷新,通過本文和大家一起學習iframe實現(xiàn)局部刷新的幾種方法匯總,對iframe局部刷新相關(guān)知識感興趣的朋友一起學習吧
    2016-01-01

最新評論