Rumah >hujung hadapan web >tutorial js >Bagaimana untuk Mengisih Objek JavaScript mengikut Nama Harta?

Bagaimana untuk Mengisih Objek JavaScript mengikut Nama Harta?

DDD
DDDasal
2024-11-02 10:00:031056semak imbas

How to Sort a JavaScript Object by Property Name?

Mengisih Objek JavaScript mengikut Nama Harta

Dalam JavaScript, susunan kekunci dalam objek tidak ditentukan. Ini boleh menyukarkan untuk mengisih objek mengikut abjad atau dalam sebarang susunan khusus lain. Walau bagaimanapun, terdapat beberapa cara untuk menyelesaikan isu ini.

Salah satu pendekatan ialah menukar objek kepada tatasusunan, mengisih tatasusunan dan kemudian menukarnya semula menjadi objek. Ini boleh dilakukan menggunakan fungsi berikut:

<code class="javascript">function sortObject(o) {
    var sorted = {},
        key, a = [];

    for (key in o) {
        if (o.hasOwnProperty(key)) {
            a.push(key);
        }
    }

    a.sort();

    for (key = 0; key < a.length; key++) {
        sorted[a[key]] = o[a[key]];
    }
    return sorted;
}</code>

Fungsi ini mengambil objek sebagai input dan mengembalikan objek baharu dengan kekunci disusun mengikut susunan abjad.

Pendekatan lain ialah menggunakan perpustakaan pihak ketiga, seperti lodash, yang menyediakan beberapa fungsi untuk bekerja dengan objek, termasuk pengisihan. Kod berikut menunjukkan cara menggunakan lodash untuk mengisih objek mengikut nama sifat:

<code class="javascript">var sortedObject = _.sortBy(o, function(value, key) {
    return key;
});</code>

Kod ini menggunakan fungsi _.sortBy untuk mengisih objek mengikut kekunci. Fungsi ini mengambil dua hujah: objek untuk diisih dan fungsi yang mengembalikan nilai untuk digunakan untuk mengisih. Dalam kes ini, fungsi hanya mengembalikan kunci objek.

Kedua-dua pendekatan ini boleh digunakan untuk mengisih objek JavaScript mengikut nama sifat. Pendekatan yang anda gunakan akan bergantung pada keperluan khusus anda.

Atas ialah kandungan terperinci Bagaimana untuk Mengisih Objek JavaScript mengikut Nama Harta?. 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