Rumah > hujung hadapan web > tutorial js > Bagaimanakah Saya Boleh Mengubah Tatasusunan 2D dalam JavaScript Menggunakan Kaedah Peta?

Bagaimanakah Saya Boleh Mengubah Tatasusunan 2D dalam JavaScript Menggunakan Kaedah Peta?

DDD
Lepaskan: 2024-12-09 14:56:11
asal
491 orang telah melayarinya

How Can I Transpose a 2D Array in JavaScript Using the Map Method?

Memindahkan Tatasusunan 2D dalam JavaScript dengan Peta

Memandangkan tatasusunan 2D, mengubahnya bermakna menukar baris dan lajurnya. Sebagai contoh, menukar tatasusunan berikut:

[
    [1,2,3],
    [1,2,3],
    [1,2,3],
]
Salin selepas log masuk

akan menghasilkan:

[
    [1,1,1],
    [2,2,2],
    [3,3,3],
]
Salin selepas log masuk

Walaupun mungkin untuk mencapai transposisi menggunakan gelung, pendekatan yang lebih ringkas menggunakan kaedah peta:

output = array[0].map((_, colIndex) => array.map(row => row[colIndex]));
Salin selepas log masuk

Kaedah peta berulang ke atas tatasusunan luar (tatasusunan pertama), mencipta tatasusunan baharu dengan memanggil fungsi panggil balik untuk setiap elemen. Dalam kes ini, fungsi panggil balik mencipta tatasusunan dalaman dengan mengulangi tatasusunan dalaman tatasusunan asal.

Parameter fungsi panggil balik termasuk:

  • _: Pembolehubah pemegang tempat yang mewakili elemen semasa tetapi tidak digunakan.
  • colIndex: Indeks semasa lajur.
  • baris: Tatasusunan dalam semasa.

Semasa setiap lelaran, fungsi panggil balik mendapatkan semula elemen pada indeks lajur yang ditentukan daripada tatasusunan dalam. Dengan berbuat demikian untuk setiap tatasusunan dalam, ia membina tatasusunan alih secara berkesan.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mengubah Tatasusunan 2D dalam JavaScript Menggunakan Kaedah Peta?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan