2011-09-09 23 views
8

Tüm ekranı doldurmak isteyen bir çok kullanıcının aksine, sadece görüntü yüksekliğini önemsiyorum. Görüntünün en boy oranını, görüntünün yeniden boyut genişliğini korurken, herhangi bir boyutta bir görüntü oluşturmak için CSS'yi (tercihen JavasScript'i değil) kullanarak, mümkün olan maksimum tarayıcı penceresinin% 100'üne kadar doldurun yüksekliği tarayıcıya önemli değildir.Görüntü, CSS ile ekran yüksekliğine nasıl yeniden boyutlandırılır?

bu html ile çalışıyorum:

<div class="images"> 
    <img/> 
</div> 

Çok teşekkür ederim!

cevap

10
img { height:100% } 

veya açık olmasını istiyorsanız

img { height:100%; width:auto; } 

yükseklik% 100: http://jsfiddle.net/jmarikle/vz7q2bnk/
genişliği% 100:

Bu cevap biraz dikkat gerekli: DÜZENLEME

http://jsfiddle.net/jmarikle/vz7q2bnk/1/ . Demo bozuldu ve genellikle karışıklık oldu. Yeni görüntülerle güncelledim, görüntülerin satır içi doğasını telafi etmek için güncellenmiş kural ve vücut ve html öğelerinin normalleştirilmiş yüksekliği ve genişliği.

+1

@Mohammad size yardımcı olmaktan mutluluk duyar :) –

+0

Bağlantılarınız çalışmıyor ... – Vickel

+0

@Vickel Aslında jsfiddle sunucu sorunları yaşıyor gibi görünüyor. 500 dahili sunucu hatası alıyorum. –

3

Bu overkill olabilir:

.img { 
    position: absolute; 
    height: 100% 
    top: 0; 
    bottom: 0; 
} 
+1

Hayır, kapsayıcı olmadığı sürece konumlandırma, üst veya alt alana ihtiyacınız dışında doğru fikir bu değil. Önemli bölüm, otomatik olarak –

+0

genişliğini bırakıyor. Evet, Joseph'in üstte veya altta gerçekten gerekli olmadığını söylediği gibi. – Mohammad

+1

uh .. bunun içinde gördüğüm şeyden, gerçekten yapmanız gereken şey kapınıza bakmanız. Bu yöntem esas olarak elemanı konteynırdan kaldırır. görüntülerinizi div 'pozisyonunu yapmaya çalışın: mutlak; sol: 0; üst: 0; yükseklik: 100%'. –

4

Ayrıca vh bir göz atmak isteyebilirsiniz, vw, vmin ve Vmax CSS birimleri - pretty well supported olan. % 100 yükseklik here elde etmeyi açıklayan iyi bir makale var.

BTW - boşluktan kaçının: bu istenmeyen bir kenar boşluğu ekleyebilir. Boşluğun kaldırılması, bir kayan nokta eklenmesi veya font-size: 0 hack'in kullanılması bu sorunu giderir. Ayrıca, diğer yöntemleri kullanırken, gövde ve html öğeleri için height: 100%'u ayarlamayı unutmayın.

İlgili konular