Rumah > hujung hadapan web > tutorial css > Bagaimana untuk Memaparkan Senarai Tidak Tertib dalam Dua Lajur Merentasi Pelayar Moden dan Legasi?

Bagaimana untuk Memaparkan Senarai Tidak Tertib dalam Dua Lajur Merentasi Pelayar Moden dan Legasi?

Barbara Streisand
Lepaskan: 2024-12-22 22:58:09
asal
110 orang telah melayarinya

How to Display an Unordered List in Two Columns Across Modern and Legacy Browsers?

Cara Memaparkan Senarai Tidak Tertib dalam Dua Lajur

Pengenalan

Soalan ini meneroka kaedah untuk mempersembahkan senarai tidak tertib merentas dua lajur, terutamanya untuk paparan dalam pelayar lama seperti Internet Explorer.

Moden Pelayar

Dalam pelayar moden, modul lajur CSS3 menyediakan sokongan untuk mencipta lajur. Dengan menggunakan modul ini, anda boleh mencapai reka letak yang diingini seperti berikut:

ul {
  columns: 2;
  -webkit-columns: 2;
  -moz-columns: 2;
}
Salin selepas log masuk

Pelayar Warisan

Untuk pelayar lama, penyelesaian berasaskan JavaScript yang melibatkan manipulasi DOM diperlukan apabila kandungan berubah. Penyelesaian ini menggunakan jQuery untuk ringkasan:

HTML:

<div>
    <ul class="columns" data-columns="2">
        <li>A</li>
        <li>B</li>
        <li>C</li>
        <li>D</li>
        <li>E</li>
        <li>F</li>
        <li>G</li>
    </ul>
</div>
Salin selepas log masuk

JavaScript:

(function($){
    var initialContainer = $('.columns'),
        columnItems = $('.columns li'),
        columns = null,
        column = 1; // account for initial column
    function updateColumns(){
        column = 0;
        columnItems.each(function(idx, el){
            if (idx !== 0 &amp;&amp; idx > (columnItems.length / columns.length) + (column * idx)){
                column += 1;
            }
            $(columns.get(column)).append(el);
        });
    }
    function setupColumns(){
        columnItems.detach();
        while (column++ < initialContainer.data('columns')){
            initialContainer.clone().insertBefore(initialContainer);
            column++;
        }
        columns = $('.columns');
    }

    $(function(){
        setupColumns();
        updateColumns();
    });
})(jQuery);
Salin selepas log masuk

CSS:

.columns{
    float: left;
    position: relative;
    margin-right: 20px;
}
Salin selepas log masuk

Nota:
Pada mulanya, penyelesaian ini akan menyusun lajur seperti berikut:

A  E
B  F
C  G
D
Salin selepas log masuk

Soalan asal meminta pesanan seperti ini sebaliknya:

A  B
C  D
E  F
G
Salin selepas log masuk

Untuk varian ini, laraskan kod JavaScript berikut:

function updateColumns(){
    column = 0;
    columnItems.each(function(idx, el){
        if (column > columns.length){
            column = 0;
        }
        $(columns.get(column)).append(el);
        column += 1;
    });
}
Salin selepas log masuk

Atas ialah kandungan terperinci Bagaimana untuk Memaparkan Senarai Tidak Tertib dalam Dua Lajur Merentasi Pelayar Moden dan Legasi?. 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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan