Rumah >hujung hadapan web >tutorial js >Bagaimanakah anda mengisih tatasusunan dua dimensi mengikut lajur tertentu dalam JavaScript?

Bagaimanakah anda mengisih tatasusunan dua dimensi mengikut lajur tertentu dalam JavaScript?

Linda Hamilton
Linda Hamiltonasal
2024-11-20 12:08:12496semak imbas

How do you sort a two-dimensional array by a specific column in JavaScript?

Mengisih Tatasusunan Dua Dimensi mengikut Nilai Lajur

Mengisih tatasusunan dua dimensi mengikut nilai lajur tertentu ialah pengaturcaraan biasa tugasan. Dalam JavaScript, ini boleh dicapai menggunakan kaedah sort(), yang mengambil fungsi perbandingan sebagai hujahnya.

Contoh: Isih mengikut Lajur Pertama

JavaScript yang disediakan coretan kod menunjukkan cara mengisih tatasusunan dua dimensi mengikut nilai dalam lajur pertama:

var a = [[12, 'AAA'], [58, 'BBB'], [28, 'CCC'],[18, 'DDD']];

a.sort(sortFunction);

function sortFunction(a, b) {
    if (a[0] === b[0]) {
        return 0;
    }
    else {
        return (a[0] < b[0]) ? -1 : 1;
    }
}

Dalam contoh ini, sortFunction mengambil dua elemen (a dan b) daripada tatasusunan dan membandingkan nilai pertamanya (a[0] dan b[0]). Jika nilai adalah sama, fungsi mengembalikan 0, menunjukkan bahawa susunan harus kekal sama. Jika a[0] kurang daripada b[0], fungsi mengembalikan -1, menunjukkan bahawa a harus didahulukan sebelum b. Jika tidak, ia mengembalikan 1, menunjukkan bahawa a harus datang selepas b.

Isih mengikut Lajur Kedua

Untuk mengisih tatasusunan mengikut lajur kedua, cuma ubah suai sortFunction kepada bandingkan nilai kedua sebaliknya:

a.sort(compareSecondColumn);

function compareSecondColumn(a, b) {
    if (a[1] === b[1]) {
        return 0;
    }
    else {
        return (a[1] < b[1]) ? -1 : 1;
    }
}

Selepas mengisih, tatasusunan akan dalam tertib menaik berdasarkan nilai dalam lajur yang ditentukan.

Atas ialah kandungan terperinci Bagaimanakah anda mengisih tatasusunan dua dimensi mengikut lajur tertentu 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