Mengapa Peratusan `margin-top` Saya Melimpahi Bekas?

Barbara Streisand
Lepaskan: 2024-11-04 09:13:30
asal
785 orang telah melayarinya

Why Does My `margin-top` Percentage Overflow the Container?

Mengira Peratusan Atas Margin: Memahami Pendekatan Berasaskan Lebar

Dalam CSS, jidar menegak, termasuk jidar atas, dikira berdasarkan lebar blok yang mengandungi. Pendekatan ini memastikan ketekalan mendatar dan menegak dalam ukuran jidar dan mengelakkan kebergantungan bulat semasa menyusun kandungan.

Ketekalan Mendatar dan Menegak:

Sifat jidar trengkas membolehkan anda menetapkan margin untuk keempat-empat sisi. Jika jidar menegak adalah berdasarkan ketinggian dan bukannya lebar, jidar pada sisi yang berbeza selalunya mempunyai saiz yang berbeza, melanggar tingkah laku yang konsisten.

Mengelakkan Kebergantungan Pekeliling:

Letak CSS keluar kandungan dalam blok menegak. Lebar blok biasanya ditentukan oleh lebar induknya. Walau bagaimanapun, ketinggian blok bergantung pada kandungannya dan boleh berubah secara dinamik. Jika jidar menegak bergantung pada ketinggian, akan terdapat kebergantungan bulat antara ketinggian ibu bapa dan jidar kanak-kanak.

Contoh:

Pertimbangkan kod berikut di mana unsur anak mempunyai margin atas: 50%:

<div class="container">
  <p>Some Cool Content</p> 
 
</div>
Salin selepas log masuk
.container {  
  background: lightblue; 
  padding: 10px; 
  height: 200px;
}

p { 
  display: block; 
  border:1px solid red;
  margin-top:50%;
}
Salin selepas log masuk

Bertentangan dengan jangkaan bahawa elemen anak akan berada 50% di bawah bahagian atas bekas (100px), ia melimpahi ketinggian bekas. Ini kerana margin peratusan adalah berdasarkan lebar bekas, bukan ketinggiannya. Dalam contoh ini, lebar bekas ialah 500px, menghasilkan margin atas 250px.

Kesimpulannya, pengiraan jidar menegak adalah berdasarkan lebar blok yang mengandungi untuk memastikan konsistensi, mengelakkan kebergantungan bulat dan membolehkan reka letak yang cekap pembinaan.

Atas ialah kandungan terperinci Mengapa Peratusan `margin-top` Saya Melimpahi Bekas?. 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