Rumah  >  Artikel  >  hujung hadapan web  >  Bagaimana untuk Meratakan Objek Bersarang dengan Satu Baris Kod JS?

Bagaimana untuk Meratakan Objek Bersarang dengan Satu Baris Kod JS?

Susan Sarandon
Susan Sarandonasal
2024-10-22 13:17:03123semak imbas

How to Flatten Nested Objects with a Single Line of JS Code?

Meratakan Objek Bersarang dengan Satu Pelapik

Meratakan objek bersarang ialah tugas biasa dalam pengaturcaraan, dan ia lebih mudah dengan JavaScript moden . Berikut ialah penyelesaian satu baris yang menggunakan operator hamparan dan Object.assign:

Object.assign({}, ...function _flatten(o) { return [].concat(...Object.keys(o).map(k => typeof o[k] === 'object' ? _flatten(o[k]) : ({[k]: o[k]})))}(yourObject))

Cara ia Berfungsi:

Kod ini menggunakan fungsi rekursif, _flatten, yang merentasi objek bersarang dan mencipta tatasusunan objek satu sifat. Setiap nama sifat dipetakan kepada nilai yang sepadan dan jika nilai itu adalah objek lain, fungsi itu berulang ke objek itu.

Operator hamparan (...) digunakan untuk meratakan tatasusunan objek yang dicipta oleh _flatten . Tatasusunan yang terhasil kemudian dihantar ke Object.assign, yang menggabungkan semua objek menjadi satu objek yang diratakan.

Contoh Input dan Output:

Pertimbangkan yang bersarang berikut objek:

{
  a: 2,
  b: {
    c: 3
  }
}

Menjalankan kod yang disediakan pada objek ini akan menghasilkan hasil yang diratakan:

{
  a: 2,
  c: 3
}

Nota:

Penyelesaian ini menggunakan ciri ES6, jadi anda mungkin perlu melaraskannya jika anda menggunakan persekitaran JavaScript yang lebih lama.

Atas ialah kandungan terperinci Bagaimana untuk Meratakan Objek Bersarang dengan Satu Baris Kod JS?. 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