CSS Bir div'in her şeyin üstünde olmasını istiyorum


Yanıtlar:


120

Z-endeksinin çalışması için, öğesine a position:absoluteveya bir position:relativeözellik vermeniz gerekir . Bunu yaptığınızda, bağlantılarınız düzgün çalışacaktır, ancak daha sonra CSS'nizi biraz değiştirmeniz gerekebilir.


Sabit bir şema kullanmak istedim ve bu yüzden konumu sabit tuttum ama yine de z-endeksini 1000 olarak ayarladım ve istenen sonuçları aldım, kaydırdığımda sayfada daha düşük bir div kapsıyordu, bunun neden olduğunu açıklayabilir misin? Statik bir pozisyon mu kullanıyordum?
Boo89100

38

İçin z-index:1000 bir etkiye sahip olmayan bir statik konumlandırma düzeni gerekir.

position:relative;Üstte olmasını istediğiniz öğeyi seçerek bir kurala ekleyin


24

Evet, z-endeksinin çalışması için öğeye bir konum vermeniz gerekir: mutlak veya konum: göreli özellik.

Ama ... ebeveynlere dikkat edin!

Ortak ebeveyn düzeyinde ilk soydan gelenlerin tanımlanmış bir z-indeksine sahip olup olmadığını kontrol etmek için öğelerin düğümlerinde yukarı çıkmanız gerekir.

Tabanda daha düşük kesin bir z-endeksi varsa, diğer tüm nesiller asla ön planda olamaz.

Bu pasaj örneğinde, div1-2-1'in z-endeksi 1000'dir, ancak yine de z-endeksi 3 olan div1-1-1'in altındadır.

Bunun nedeni, div1-1'in div1-2'den büyük bir z-endeksine sahip olmasıdır.

görüntü açıklamasını buraya girin

.div {
  
}

#div1 {
  z-index: 1;
  position: absolute;
  width: 500px;
  height: 300px;
  border: 1px solid black;
}

#div1-1 {
  z-index: 2;
  position: absolute;
  left: 230px;
  width: 200px;
  height: 200px;
  top: 31px;
  background-color: indianred;
}

#div1-1-1 {
  z-index: 3;
  position: absolute;
  top: 50px;
  width: 100px;
  height: 100px;
  background-color: burlywood;
}

#div1-2 {
  z-index: 1;
  position: absolute;
  width: 200px;
  height: 200px;
  left: 80px;
  top: 5px;
  background-color: red;
}

#div1-2-1 {
  z-index: 1000;
  position: absolute;
  left: 70px;
  width: 120px;
  height: 100px;
  top: 10px;
  color: red;
  background-color: lightyellow;
}

.blink {
  animation: blinker 1s linear infinite;
}

@keyframes blinker {
  50% {
    opacity: 0;
  }
}

.rotate {
  writing-mode: vertical-rl;
  padding-left: 50px;
  font-weight: bold;
  font-size: 20px;
}
<div class="div" id="div1">div1</br>z-index: 1
  <div class="div" id="div1-1">div1-1</br>z-index: 2
    <div class="div" id="div1-1-1">div1-1-1</br>z-index: 3</div>
  </div>
  
  <div class="div" id="div1-2">div1-2</br>z-index: 1</br><span class='rotate blink'><=</span>
    <div class="div" id="div1-2-1"><span class='blink'>z-index: 1000!!</span></br>div1-2-1</br><span class='blink'> because =></br>(same</br>   parent)</span></div>
  </div>
</div>


Sen bir hayat kurtarıcısın!
Benjamin Karlog

16

position:relative;Menüye eklemeniz gerekiyor . Z-endeksi yalnızca statik olmayan bir konumlandırma şemanız olduğunda çalışır.


9

z-indexmülkiyet, kontrolünüzü önünüze almanızı sağlar. daha büyük sayı, elde ettiğiniz öğenizin üst kısmını ayarlarsınız.

positionözelliği, relativekonumu html-elementtüm boyutlarda diğer kontrollere göre göreceli olarak konumlandırılması gerektiğinden olmalıdır.

element.style {
   position:relative;
   z-index:1000; //change your number as per elements lies on your page.
}

4

3.Dünya Savaşı okulunun koduyla bir pop-up yaptığını varsayacağım, değil mi? kontrol et css. .modal olanı, orada zaten kelime z-indexvar. sadece 1'den 100'e değiştirin.

.modal {
    display: none; /* Hidden by default */
    position: fixed; /* Stay in place */
    z-index: 1; /* Sit on top */
    padding-top: 100px; /* Location of the box */
    left: 0;
    top: 0;
    width: 100%; /* Full width */
    height: 100%; /* Full height */
    overflow: auto; /* Enable scroll if needed */
    background-color: rgb(0,0,0); /* Fallback color */
    background-color: rgba(0,0,0,0.4); /* Black w/ opacity */
}
Sitemizi kullandığınızda şunları okuyup anladığınızı kabul etmiş olursunuz: Çerez Politikası ve Gizlilik Politikası.
Licensed under cc by-sa 3.0 with attribution required.