第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

js,ES6有方便拆分?jǐn)?shù)組的方法嗎?1,2,3,4,5,6拆1.3.5和2,4,6,類(lèi)似java8的groupingBy?

js,ES6有方便拆分?jǐn)?shù)組的方法嗎?1,2,3,4,5,6拆1.3.5和2,4,6,類(lèi)似java8的groupingBy?

白衣染霜花 2019-01-16 02:48:46
目前了解的解決辦法 const oldList = [1, 2, 3, 4, 5, 6, 7] // 使用reduce函數(shù)接受一個(gè)初始值{ 0: [], 1: [], length: 2 }, // 初始值包含兩個(gè)空數(shù)組,和一個(gè)數(shù)組長(zhǎng)度(Array.from方法要求將對(duì)象轉(zhuǎn)數(shù)組時(shí)對(duì)象內(nèi)要有這個(gè)屬性) // 在reduce函數(shù)內(nèi)根據(jù)索引做余2判斷,因?yàn)榉謨闪?,?的加入第一個(gè)數(shù)組,余1的加入第二個(gè)數(shù)組 // 最后reduce返回遍歷完的對(duì)象 {0:[1,3,5,7],1:[2,4,6],length:2} // 使用Array.from({0:[1,3,5,7],1:[2,4,6],length:2}) 得到 數(shù)組 [[1,3,5,7],[2,4,6]] // 解構(gòu)數(shù)組 使用concat合并,完事 const newList = [].concat(...(Array.from(oldList.reduce((total, cur, index) => { total[index % 2].push(cur) return total }, { 0: [], 1: [], length: 2 })))) console.log(newList) 輸出 [1, 3, 5, 7, 2, 4, 6] 然后再將兩個(gè)數(shù)組合并, 總之就是我想將[1,2,3,4,5,6]拆成[1.3.5]和[2,4,6]然后再合并成 有什么最簡(jiǎn)潔,代碼最少的方法將 [1,2,3,4,5,6]改為[1,3,5,2,4,6], 最好只遍歷一次數(shù)組 java代碼: List里面的對(duì)象元素,以某個(gè)屬性來(lái)分組,例如,以id分組,將id相同的放在一起: 復(fù)制代碼 //List 以ID分組 Map<Integer,List<Apple>> Map<Integer, List<Apple>> groupBy = appleList.stream().collect(Collectors.groupingBy(Apple::getId)); System.err.println("groupBy:"+groupBy); {1=[Apple{id=1, name='蘋(píng)果1', money=3.25, num=10}, Apple{id=1, name='蘋(píng)果2', money=1.35, num=20}], 2=[Apple{id=2, name='香蕉', money=2.89, num=30}], 3=[Apple{id=3, name='荔枝', money=9.99, num=40}]}
查看完整描述

9 回答

?
天涯盡頭無(wú)女友

TA貢獻(xiàn)1831條經(jīng)驗(yàn) 獲得超9個(gè)贊

這是題主按照答主思路寫(xiě)的一個(gè)思路一樣,但實(shí)現(xiàn)不完全一樣的符合題主要求的答案

const oldList = [1, 2, 3, 4, 5, 6, 7]

// 使用reduce函數(shù)接受一個(gè)初始值{ 0: [], 1: [], length: 2 },
// 初始值包含兩個(gè)空數(shù)組,和一個(gè)數(shù)組長(zhǎng)度(Array.from方法要求將對(duì)象轉(zhuǎn)數(shù)組時(shí)對(duì)象內(nèi)要有這個(gè)屬性)
// 在reduce函數(shù)內(nèi)根據(jù)索引做余2判斷,因?yàn)榉謨闪?,?的加入第一個(gè)數(shù)組,余1的加入第二個(gè)數(shù)組
// 最后reduce返回遍歷完的對(duì)象 {0:[1,3,5,7],1:[2,4,6],length:2}
// 使用Array.from({0:[1,3,5,7],1:[2,4,6],length:2}) 得到 數(shù)組 [[1,3,5,7],[2,4,6]]
// 解構(gòu)數(shù)組 使用concat合并,完事
const newList = [].concat(...(Array.from(oldList.reduce((total, cur, index) => {
  total[index % 2].push(cur)
  return total
}, { 0: [], 1: [], length: 2 }))))

console.log(newList)   

輸出

 [1, 3, 5, 7, 2, 4, 6]

已下為答主提供的實(shí)現(xiàn)方式及思路,謝謝------------------------------------------------------

const arr = [1,2,3,4,5,6]

const newArr = [...arr.filter(e => e % 2), ...arr.filter(e => e % 2 === 0)]

其實(shí)也沒(méi)必要追求這點(diǎn)性能, 既要代碼少, 又要效率高... 我覺(jué)得乖乖寫(xiě)for循環(huán)最好了

嗯...
const obj = arr.reduce((a, b) => {
    a[b%2].push(b)
    return a
}, {0: [], 1: []})

const newArr = obj[1].concat(obj[0])

遍歷一次呦 不知道合不合樓主口味
查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
慕無(wú)忌1623718

TA貢獻(xiàn)1744條經(jīng)驗(yàn) 獲得超4個(gè)贊

            function arrSort(arr, newArr = []) {
                arr.map((item, i, arr) => {
                    if (item % 2 === 0) {
                        newArr.push(item)
                        arr.splice(i, 1)
                    }
                })
                return arr.concat(newArr)
            }
查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
小唯快跑啊

TA貢獻(xiàn)1863條經(jīng)驗(yàn) 獲得超2個(gè)贊

自定義排序吧,畢竟最后還是要一個(gè)數(shù)組
array.sort(function(a,b){
...
})

查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
莫回?zé)o

TA貢獻(xiàn)1865條經(jīng)驗(yàn) 獲得超7個(gè)贊

const groupBy = (original, fn) => {
  if ((!Array.isArray(original)) || (!(fn instanceof Function))) throw Error('')
  const fit = []
  const unfit = []
  original.forEach(el => {
    fn(el) ? fit.push(el) : unfit.push(el)
  })
  return {fit, unfit}
}
groupBy([1,2,3,4,5,6],el=>{return el%2})//=>{fit:[1, 3, 5],unfit [2, 4, 6]}
查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
梵蒂岡之花

TA貢獻(xiàn)1900條經(jīng)驗(yàn) 獲得超5個(gè)贊

lodash有已封裝的groupBy

查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
慕虎7371278

TA貢獻(xiàn)1802條經(jīng)驗(yàn) 獲得超4個(gè)贊

{
  const arr = [1,2,3,4,5,6]
  const even = []
  const odd = arr.filter(item => {
    if(item % 2 === 0){
      even.push(item)
    }
    return item % 2 === 1;
  })
  console.log(odd);
  console.log(even);
}
查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
一只名叫tom的貓

TA貢獻(xiàn)1906條經(jīng)驗(yàn) 獲得超3個(gè)贊

function groupBy( array , f ) {
    let groups = {};
    array.forEach( function( o ) {
        let group = JSON.stringify( f(o) );
        groups[group] = groups[group] || [];
        groups[group].push( o );
    });
    return Object.keys(groups).map( function( group ) {
        return groups[group];
    });
}

基本用法

var arr = [1,2,3,4,5,6];
groupBy(arr,function(a){return a % 2 == 0;})

擴(kuò)展用法

var arr = [{name:"a",age:2},{"name":"b",age:1},{"name":"c",age:1}];
groupBy(arr,function(a){return [a.age]})
查看完整回答
反對(duì) 回復(fù) 2019-02-12
?
暮色呼如

TA貢獻(xiàn)1853條經(jīng)驗(yàn) 獲得超9個(gè)贊

很簡(jiǎn)單,用filter和展開(kāi)就可以

const baseArray = [1,2,3,4,5,6];

const oddArray = baseArray.filter(number => number % 2 === 1);

const evenArray = baseArray.filter(number => number % 2 === 0);

const finalArray = [...oddArray, ...evenArray];
查看完整回答
反對(duì) 回復(fù) 2019-02-12
  • 9 回答
  • 0 關(guān)注
  • 2020 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)