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

Bagaimana untuk Meratakan Objek Bersarang dengan Satu Baris Kod JS?

Susan Sarandon
Lepaskan: 2024-10-22 13:17:03
asal
237 orang telah melayarinya

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))
Salin selepas log masuk

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
  }
}
Salin selepas log masuk

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

{
  a: 2,
  c: 3
}
Salin selepas log masuk

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!

sumber:php
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan