Rumah >hujung hadapan web >tutorial js >Bagaimanakah Saya Boleh Mengisih Tatasusunan Objek mengikut Pelbagai Medan dalam JavaScript?

Bagaimanakah Saya Boleh Mengisih Tatasusunan Objek mengikut Pelbagai Medan dalam JavaScript?

DDD
DDDasal
2024-12-17 05:53:24423semak imbas

How Can I Sort an Array of Objects by Multiple Fields in JavaScript?

Isih Tatasusunan Objek mengikut Pelbagai Medan

Dalam soalan asal, mengisih tatasusunan objek mengikut satu medan telah diselesaikan dengan cekap. Walau bagaimanapun, bagaimanakah kita boleh menggunakan isihan pada berbilang medan?

Untuk mengisih tatasusunan objek mengikut berbilang medan, kita boleh menggunakan pendekatan pengisihan berantai. Ini melibatkan pengisihan mengikut medan pertama dan kemudian, jika nilainya sama, teruskan mengisih mengikut medan kedua. Jika perlu, proses ini boleh diulang untuk lebih banyak medan.

Pertimbangkan contoh berikut di mana kita ingin mengisih susunan rumah mengikut bandar (menaik) dan kemudian harga (menurun):

var homes = [
    {"h_id":"3",
     "city":"Dallas",
     "state":"TX",
     "zip":"75201",
     "price":"162500"},
    {"h_id":"4",
     "city":"Bevery Hills",
     "state":"CA",
     "zip":"90210",
     "price":"319250"},
    {"h_id":"6",
     "city":"Dallas",
     "state":"TX",
     "zip":"75000",
     "price":"556699"},
    {"h_id":"5",
     "city":"New York",
     "state":"NY",
     "zip":"00010",
     "price":"962500"}
    ];

Untuk mengisih tatasusunan ini, kita boleh menggunakan kod JavaScript berikut:

homes.sort(function (a, b) {
    return a.city.localeCompare(b.city) || b.price - a.price;
});

Begini caranya kod ini berfungsi:

  1. Fungsi isihan mengambil fungsi perbandingan sebagai hujahnya. Fungsi ini membandingkan dua elemen dalam tatasusunan.
  2. Dalam fungsi perbandingan kami, kami mula-mula membandingkan bandar kedua-dua rumah itu. Jika ia adalah sama, kami meneruskan untuk membandingkan harga mereka.
  3. Fungsi localeCompare membandingkan dua rentetan dan mengambil kira tempat penyemak imbas. Ini memastikan pengisihan adalah konsisten merentas tempat yang berbeza.
  4. || operator digunakan untuk melaksanakan operasi OR logik. Jika perbandingan bandar mengembalikan nilai bukan sifar, ini bermakna kedua-dua rumah mempunyai bandar yang berbeza dan perbandingan bandar harus digunakan untuk mengisih. Jika tidak, perbandingan harga digunakan.
  5. Jika perbandingan harga mengembalikan nilai negatif, bermakna rumah pertama mempunyai harga yang lebih rendah daripada rumah kedua. Jika ia mengembalikan nilai positif, rumah pertama mempunyai harga yang lebih tinggi daripada rumah kedua. Algoritma pengisihan akan menggunakan nilai ini untuk menentukan susunan rumah.

Dengan menggunakan pendekatan pengisihan ini pada berbilang medan, kita boleh mengisih tatasusunan objek yang kompleks mengikut susunan yang dikehendaki dengan mudah.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengisih Tatasusunan Objek mengikut Pelbagai Medan dalam JavaScript?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn