Rumah > hujung hadapan web > tutorial css > Bagaimana untuk Menyusun Elemen Bertindih Bertindih Secara Benar dalam CSS?

Bagaimana untuk Menyusun Elemen Bertindih Bertindih Secara Benar dalam CSS?

DDD
Lepaskan: 2024-12-10 09:04:10
asal
753 orang telah melayarinya

How to Vertically Stack Overlapping Absolutely Positioned Elements in CSS?

Menyelesaikan Pertindihan Elemen Kedudukan Mutlak untuk Susunan Menegak

Dalam CSS, sifat kedudukan boleh ditetapkan kepada pelbagai nilai, termasuk relatif, mutlak dan tetap. Apabila sesuatu elemen diletakkan secara mutlak, ia dialih keluar daripada aliran dokumen biasa dan diposisikan secara relatif kepada nenek moyang kedudukan terdekatnya atau ruang pandang. Tingkah laku ini boleh menyebabkan elemen disusun di atas satu sama lain, yang mungkin bukan kesan yang diingini.

Memahami Kedudukan Elemen

  • Statik (lalai): Elemen bertindan seperti biasa dalam aliran dokumen.
  • Relatif: Elemen kekal dalam aliran dokumen, tetapi kedudukannya boleh dilaraskan menggunakan bahagian atas, kanan, bawah dan kiri.
  • Mutlak: Elemen dialih keluar daripada aliran dokumen dan diletakkan secara relatif kepada yang terdekat. nenek moyang berkedudukan.

Bertindih Elemen Kedudukan Mutlak

Dalam contoh berikut, unsur-unsur dengan kelas .row dan .col diposisikan secara mutlak, menyebabkan ia bertindih:

body {
  position: relative; /* Contains absolutely positioned elements */
}

.container {
  position: absolute;
}

.row {
  position: relative;
}

.col1, .col2 {
  position: absolute;
}
Salin selepas log masuk

Untuk menyelesaikan isu ini dan mempunyai elemen tindanan secara menegak, kita perlu menentukan ketinggiannya dan pastikan kedudukan menegak mereka diuruskan dengan betul.

Penyelesaian Tanpa Mengalihkan Sifat Kedudukan

Sementara itu tidak sesuai untuk mengubah suai CSS untuk elemen, penyelesaian yang mungkin tanpa mengalih keluar sifat kedudukan adalah dengan menentukan ketinggian setiap .row dan melaraskan sifat atas .row kedua untuk mengambil kira ketinggian .row pertama:

body {
  /* position: relative; remains unchanged */
}

.container {
  /* position: absolute; remains unchanged */
}

.row {
  position: relative;
  height: 2em; /* Specify height for vertical stacking */
}

.col1, .col2 {
  /* position: absolute; remains unchanged */
}

#row2 {
  top: 2em; /* Offset to account for the height of #row1 */
}
Salin selepas log masuk

Memahami Penyelesaian

  • Kami mengekalkan kedudukan mutlak elemen.
  • Kami nyatakan ketinggian bagi setiap .baris untuk membolehkan tindanan menegak.
  • Kami melaraskan sifat atas .row kedua (#row2) untuk mengimbanginya dengan ketinggian .row pertama (#row1).

Pertimbangan

  • Pastikan ketinggian elemen .row adalah tepat dan termasuk sebarang pelapik atau margin.
  • Penyelesaian ini mungkin tidak sesuai untuk kandungan yang dijana secara dinamik dengan ketinggian yang tidak diketahui.
  • Secara amnya, tidak disyorkan untuk mempunyai berbilang elemen kedudukan mutlak bersarang kerana ia boleh membawa kepada tingkah laku yang kompleks.

Atas ialah kandungan terperinci Bagaimana untuk Menyusun Elemen Bertindih Bertindih Secara Benar dalam CSS?. 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