Rumah  >  Soal Jawab  >  teks badan

Cara paling berkesan untuk mengumpulkan tatasusunan objek

<p>Apakah cara yang paling berkesan untuk mengumpulkan objek dalam tatasusunan? </p> <p>Sebagai contoh, diberikan tatasusunan objek berikut: </p> <pre class="brush:php;toolbar:false;">[ { Fasa: "Fasa 1", Langkah: "Langkah 1", Tugas: "Tugas 1", Nilai: "5" }, { Fasa: "Fasa 1", Langkah: "Langkah 1", Tugasan: "Tugas 2", Nilai: "10" }, { Fasa: "Fasa 1", Langkah: "Langkah 2", Tugasan: "Tugas 1", Nilai: "15" }, { Fasa: "Fasa 1", Langkah: "Langkah 2", Tugas: "Tugas 2", Nilai: "20" }, { Fasa: "Fasa 2", Langkah: "Langkah 1", Tugasan: "Tugas 1", Nilai: "25" }, { Fasa: "Fasa 2", Langkah: "Langkah 1", Tugasan: "Tugas 2", Nilai: "30" }, { Fasa: "Fasa 2", Langkah: "Langkah 2", Tugasan: "Tugas 1", Nilai: "35" }, { Fasa: "Fasa 2", Langkah: "Langkah 2", Tugasan: "Tugas 2", Nilai: "40" } ]</pre> <p>Saya memaparkan maklumat ini dalam jadual. Saya mahu mengumpulkan mengikut kaedah yang berbeza tetapi saya mahu menjumlahkan nilainya. </p> <p>Saya menggunakan fungsi groupby Underscore.js, yang berguna, tetapi tidak cukup memenuhi keperluan kerana saya tidak mahu "memisahkan" mereka tetapi "mencantumkan" mereka, lebih seperti kumpulan SQL dengan kaedah. </p> <p>Apa yang saya mahukan ialah dapat menjumlahkan nilai tertentu jika perlu. </p> <p>Jadi, jika saya mengumpulkan mengikut <kod>Fasa</kod>, saya ingin mendapatkan: </p> <pre class="brush:php;toolbar:false;">[ { Fasa: "Fasa 1", Nilai: 50 }, { Fasa: "Fasa 2", Nilai: 130 } ]</pre> <p>Jika saya mengumpulkan mengikut <kod>Fasa</kod> <pre class="brush:php;toolbar:false;">[ { Fasa: "Fasa 1", Langkah: "Langkah 1", Nilai: 15 }, { Fasa: "Fasa 1", Langkah: "Langkah 2", Nilai: 35 }, { Fasa: "Fasa 2", Langkah: "Langkah 1", Nilai: 55 }, { Fasa: "Fasa 2", Langkah: "Langkah 2", Nilai: 75 } ]</pre> <p>Adakah terdapat skrip yang berguna untuk mencapai ini, atau adakah saya perlu terus menggunakan Underscore.js dan melakukan penjumlahan dengan menggelung pada objek hasil? </p>
P粉310754094P粉310754094447 hari yang lalu579

membalas semua(2)saya akan balas

  • P粉029327711

    P粉0293277112023-08-22 12:54:13

    Menggunakan objek Peta ES6:

    /**
     * @description
     * 接受一个类型为V的数组和一个分组函数,返回按照分组函数分组的数组的Map。
     *
     * @param list 类型为V的数组。
     * @param keyGetter 一个函数,接受类型为V的数组作为输入,并返回类型为K的值。
     *                  K通常是V的属性键。
     *
     * @returns 按照分组函数分组的数组的Map。
     */
    //export function groupBy<K, V>(list: Array<V>, keyGetter: (input: V) => K): Map<K, Array<V>> {
    //    const map = new Map<K, Array<V>>();
    function groupBy(list, keyGetter) {
        const map = new Map();
        list.forEach((item) => {
             const key = keyGetter(item);
             const collection = map.get(key);
             if (!collection) {
                 map.set(key, [item]);
             } else {
                 collection.push(item);
             }
        });
        return map;
    }
    
    
    // 使用示例
    
    const pets = [
        {type:"Dog", name:"Spot"},
        {type:"Cat", name:"Tiger"},
        {type:"Dog", name:"Rover"}, 
        {type:"Cat", name:"Leo"}
    ];
        
    const grouped = groupBy(pets, pet => pet.type);
        
    console.log(grouped.get("Dog")); // -> [{type:"Dog", name:"Spot"}, {type:"Dog", name:"Rover"}]
    console.log(grouped.get("Cat")); // -> [{type:"Cat", name:"Tiger"}, {type:"Cat", name:"Leo"}]
    
    const odd = Symbol();
    const even = Symbol();
    const numbers = [1,2,3,4,5,6,7];
    
    const oddEven = groupBy(numbers, x => (x % 2 === 1 ? odd : even));
        
    console.log(oddEven.get(odd)); // -> [1,3,5,7]
    console.log(oddEven.get(even)); // -> [2,4,6]

    Mengenai Peta: https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Map

    balas
    0
  • P粉590428357

    P粉5904283572023-08-22 11:08:27

    Jika anda ingin mengelak daripada menggunakan perpustakaan luaran, anda boleh melaksanakan versi asli groupBy() seperti ini:

    var groupBy = function(xs, key) {
      return xs.reduce(function(rv, x) {
        (rv[x[key]] = rv[x[key]] || []).push(x);
        return rv;
      }, {});
    };
    
    console.log(groupBy(['one', 'two', 'three'], 'length'));
    
    // => {"3": ["one", "two"], "5": ["three"]}

    balas
    0
  • Batalbalas