Kutu modeli: CSS çerçevesi
- Önceki Sayfa CSS İç Kenar Boşluğu
- Sonraki Sayfa CSS Kenar Boşluğu
Elementin çerçevesi (border), element içeriği ve iç kenar boşluğunu çevreleyen bir veya daha fazla çizgidir.
CSS border özelliği, element çerçevesinin tarzını, genişliğini ve rengini belirlemenize olanak tanır.
CSS Kenar
HTML'de, metin etrafında çerçeve oluşturmak için tablolar kullanırız, ancak CSS çerçeve özelliklerini kullanarak herhangi bir elemente etkileyici bir çerçeve oluşturabilir ve uygulamak için kullanabiliriz.
Elementin dış kenar boşluğu içindeki çerçeve, elementin çerçevesidir (border). Elementin çerçevesi, element içeriği ve iç kenar boşluğunu çevreleyen bir veya daha fazla çizgidir.
Her çerçeve 3 yönü vardır: genişlik, tarz ve renk. Aşağıdaki bölümlerde, bu üç yönü ayrıntılı olarak açıklayacağız.
Çerçeve ile arka plan
CSS normları, çerçevelerin 'elementin arka planının üzerinde' çizildiğini belirtir. Bu çok önemlidir, çünkü bazı çerçeveler 'aralı' (örneğin, noktalı çizgili veya ince çizgili) olabilir, elementin arka planı çerçevenin görünür kısımları arasında görünmelidir.
CSS2, arka planın yalnızca iç kenar boşluğuna kadar uzandığını belirtir, çerçeve değil. CSS2.1 daha sonra düzeltti: elementin arka planı, içerik, iç kenar boşluğu ve çerçeve alanının arka planıdır. Çoğu tarayıcı CSS2.1'i takip eder, ancak bazı eski tarayıcılar farklı bir performans gösterebilir.
Çerçeve tarzı
Tarz, çerçevenin en önemli yönlerinden biridir, bu çerçeve tarzı çerçevelerin görünürlüğünü kontrol ediyor değil (tabii ki, çerçeve tarzı çerçevelerin görünürlüğünü kontrol ediyor), çünkü tarz olmadan çerçeve olmayacak.
CSS'nin border-style özelliği10 adet farklı non-inherit tarz tanımladı, bunlar arasında none da var.
Örneğin, bir resmin çerçevesini outset olarak ayarlayabilir ve bu şekilde 'çıkıntılı düğme' gibi görünmesini sağlayabilirsiniz:
a:link img {border-style: outset;}
Çoklu tarz tanımlama
Bir çerçeveye birden fazla tarz tanımlayabilirsiniz, örneğin:
p.aside {border-style: solid dotted dashed double;}
Yukarıdaki bu kural, sınıfı aside olan paragraflar için dört tür çerçeve tarzı tanımlar: kalın çizgili üst çerçeve, noktalı çizgili sağ çerçeve, ince çizgili alt çerçeve ve çift çizgili sol çerçeve.
Burada değeri top-right-bottom-left sırası ile kullanıyor gördük, birden fazla değerle farklı iç kenar boşluklarını ayarlamak için de bu sırayı gördük.
Tek kenar tarzı tanımlama
Bir eleman çerçevesinin belirli bir kenarının çerçeve tarzını ayarlamak istiyorsanız, tüm 4 kenarın çerçeve tarzını ayarlamak yerine aşağıdaki tek kenar çerçeve tarzı özelliklerini kullanabilirsiniz:
Bu nedenle bu iki yöntem eşdeğerdir:
p {border-style: solid solid solid none;} p {border-style: solid; border-left-style: none;}
Dikkat:İkinci yöntemi kullanmak için, tek kenar özelliklerini kısa yazım özelliği ardından koymak zorundasınız. Çünkü border-style öncesinde tek kenar özelliği yerleştirilirse, kısa yazım özelliğinin değeri tek kenar değerini none ile geçersiz kılar.
çerçeve genişliği
Çerçeve genişliğini border-width özelliğiÇerçeve genişliğini belirleme
Çerçeve genişliğini belirlemek için iki yöntem vardır: uzunluk değerleri belirtebilirsiniz, örneğin 2px veya 0.1em; veya thin, medium (varsayılan değer) ve thick gibi 3 anahtar kelimenin birini kullanabilirsiniz.
Not:CSS, 3 adet anahtar kelimenin belirli genişliklerini tanımlamamıştır, bu yüzden bir kullanıcı aracı thin, medium (varsayılan değer) ve thick olarak 5px, 3px ve 2px olarak ayarlayabilirken, başka bir kullanıcı aracı ise 3px, 2px ve 1px olarak ayarlayabilir.
Bu nedenle, çerçeve genişliğini böyle ayarlayabiliriz:
p {border-style: solid; border-width: 5px;}
veya:
p {border-style: solid; border-width: thick;}
Tek kenar genişliği tanımlama
Top-right-bottom-left sırasına göre elementin her kenar çerçevesini ayarlayabilirsiniz:
p {border-style: solid; border-width: 15px 5px 15px 5px;}
Yukarıdaki örnekte de öyle, bu yazım tarzınaDeğer kopyalama):
p {border-style: solid; border-width: 15px 5px;}
Ayrıca, çerçevenin her kenarının genişliğini aşağıdaki özelliklerle ayrı ayrı ayarlayabilirsiniz:
Bu nedenle, aşağıdaki kurallar yukarıdaki örnekle eşdeğerdir:
p { border-style: solid; border-top-width: 15px; border-right-width: 5px; border-bottom-width: 15px; border-left-width: 5px; }
Çerçeve yok
Önceki örnekte gördüğünüz gibi, bir tür çerçeve göstermek istiyorsanız, çerçeve stili ayarlamak zorundasınız, örneğin solid veya outset.
Eğer border-style none olarak ayarlanırsa ne olacaktır:
p {border-style: none; border-width: 50px;}
Çerçeve genişliği 50px olmasına rağmen, çerçeve tarzı none olarak ayarlanmıştır. Bu durumda, sadece çerçeve tarzı kaybolmaz, genişliği de 0 olur. Çerçeve gitti, neden?
Bu, çerçeve tarzı none olduğunda, yani çerçeve tamamen yoksa, çerçeve genişliği olmayacağı için, çerçeve genişliği otomatik olarak 0 olarak ayarlanır, ne kadar tanımlarsanız tanımlayın.
Bu noktayı unutmamak çok önemlidir. Aslında, çerçeve tarzını unutmak sıkça yapılan bir hatadır. Aşağıdaki kurallara göre, tüm h1 öğeleri hiçbir çerçeve olmayacak, 20 piksel genişliği bile olmayacaktır:
h1 {border-width: 20px;}
border-style'nin varsayılan değeri none olduğundan, tarzı tanımlamadıysanız, border-style: none demektir.Bu yüzden, çerçeve görünmesini istiyorsanız, bir çerçeve tarzı tanımlamanız gerekir.
çerçeve rengi
Çerçeve rengi ayarlamak çok basittir. CSS, basit bir border-color özelliğiher seferinde en fazla 4 renk değeri alabilir.
Her türlü renk değeri kullanılabilir, örneğin adlandırılmış renkler, onaltılık ve RGB değerleri olabilir:
p { border-style: solid; border-color: blue rgb(25%,35%,45%) #909090 red; }
Renk değeri 4'ten azsa, değer kopyalama işlemi geçerlidir. Örneğin aşağıdaki kurallar, paragrafın üst ve alt çerçevelerinin mavi, sol ve sağ çerçevelerinin kırmızı olacağını belirtir:
p { border-style: solid; border-color: blue red; }
Not:Varsayılan çerçeve rengi, öğenin ön rengidir. Çerçeve rengi için renk tanımlanmadıysa, çerçeve rengi metin rengi ile aynı olacaktır. Diğer yandan, öğe hiç metin içermiyorsa, örneğin sadece resimler içeren bir tablo ise, bu tablonun çerçeve rengi, ebeveyn öğenin metin rengidir (çünkü color miras alabilir). Bu ebeveyn öğe, büyük olasılıkla body, div veya başka bir table olabilir.
Tek kenar renk tanımlama
Ayrıca bazı tek kenar çerçeve renk özellikleri vardır. Onların prensibi, tek kenar tarzı ve genişlik özellikleri ile aynıdır:
h1 öğesine kalın siyah çerçeve belirlemek ve sağ çerçeveyi kalın kırmızı olarak belirlemek için şöyle belirtebilirsiniz:
h1 { border-style: solid; border-color: black; border-right-color: red; }
Şeffaf çerçeve
Daha önce bahsettiğimiz gibi, çerçeve tarzı yoksa, genişliği yok demektir. Ancak bazı durumlarda görünmez bir çerçeve oluşturmak isteyebilirsiniz.
CSS2 ekranın renk değerini şeffaf olarak tanıttı. Bu değer, genişliği olan görünmez bir çerçeve oluşturmak için kullanılır. Aşağıdaki örneği inceleyin:
<a href="#">AAA</a> <a href="#">BBB</a> <a href="#">CCC</a>
Üstteki bağlantılar için aşağıdaki stilleri tanımladık:
a:link, a:visited { border-style: solid; border-width: 5px; border-color: transparent; } a:hover {border-color: gray;}
Bir anlamda, transparent kullanarak, kenarları ek iç boşluk gibi kullanabilirsiniz; ayrıca, ihtiyacınız olduğunda görünür hale getirebilirsiniz. Bu şeffaf kenar, iç boşluğa benzer, çünkü elemanın arka planı, kenar alanına uzanır (görünür bir arka plan varsa).
Önemli Not:IE7'den önce, IE/WIN, transparent'e destek sağlamamıştır. Daha önceki sürümlerde, IE, kenar rengini elemanın color değeri temelinde ayarlamıştır.
CSS Kenar Örneği:
- Tüm kenar özellikleri bir açıklamada
- Bu örnek, tüm dört kenarın özelliklerini aynı açıklamada belirlemek için kısa yazım özelliğini kullanır.
- Dört kenarın tarzını ayarlamak
- Bu örnek, dört kenarın tarzını nasıl ayarlayacağınızı gösterir.
- Her kenarda farklı çerçeve ayarlamak
- Bu örnek, elementin her kenarında farklı çerçeve nasıl ayarlanacağını gösterir.
- Tüm kenar genişlik özellikleri bir açıklamada
- Bu örnek, tüm kenar genişlik özelliklerini aynı açıklamada belirlemek için kısa yazım özelliğini kullanır.
- Dört kenarın rengini ayarlamak
- Bu örnek, dört kenarın rengini nasıl ayarlayacağınızı gösterir. Bir ila dört renk ayarlanabilir.
- Tüm alt çerçeve özellikleri bir açıklamada
- Bu örnek, tüm alt çerçeve özelliklerini aynı açıklamada belirlemek için kısa yazım özelliğini kullanır.
- Alt çerçevenin rengini ayarlamak
- Bu örnek, alt çerçevenin rengini nasıl ayarlayacağınızı gösterir.
- Alt çerçevenin tarzını ayarlamak
- Bu örnek, alt çerçevenin tarzını nasıl ayarlayacağınızı gösterir.
- Alt çerçeve genişliğini ayarlamak
- Bu örnek, alt çerçeve genişliğini nasıl ayarlayacağınızı gösterir.
- Tüm sol çerçeve özellikleri bir açıklamada
- Tüm sol çerçeve özellikleri bir açıklamada
- Sol çerçevenin rengini ayarlamak
- Bu örnek, sol çerçevenin rengini nasıl ayarlayacağınızı gösterir.
- Sol çerçevenin tarzını ayarlamak
- Bu örnek, sol çerçevenin tarzını nasıl ayarlayacağınızı gösterir.
- Sol çerçeve genişliğini ayarlamak
- Bu örnek, sol çerçeve genişliğini nasıl ayarlayacağınızı gösterir.
- Tüm sağ çerçeve özellikleri bir açıklamada
- Bu örnek, tüm sağ çerçeve özelliklerini bir açıklamada belirlemek için kısa yazım özelliğini kullanır.
- Sağ çerçevenin rengini ayarlamak
- Bu örnek, sağ çerçevenin rengini nasıl ayarlayacağınızı gösterir.
- Sağ çerçevenin tarzını ayarlamak
- Bu örnek, sağ çerçevenin tarzını nasıl ayarlayacağınızı gösterir.
- Sağ çerçeve genişliğini ayarlamak
- Bu örnek, sağ çerçeve genişliğini nasıl ayarlayacağınızı gösterir.
- Tüm üst çerçeve özellikleri bir açıklamada
- Bu örnek, tüm üst çerçeve özelliklerini aynı açıklamada belirlemek için kısa yazım özelliğini gösterir.
- Üst çerçevenin rengi ayarlayın
- Bu örnekte, üst çerçevenin rengi nasıl ayarlanacağı gösterilir.
- Üst çerçevenin stili ayarlayın
- Bu örnekte, üst çerçevenin stili nasıl ayarlanacağı gösterilir.
- Üst çerçevenin genişliğini ayarlayın
- Bu örnekte, üst çerçevenin genişliğini nasıl ayarlayacağınız gösterilir.
CSS Kenar Özellikleri
Özellik | Açıklama |
---|---|
border | Kısaltma özelliği, dört kenarın özelliklerini bir bildiride birleştirmek için kullanılır. |
border-style | Elemanın tüm çerçevelerinin stilini ayarlar veya her kenar çerçevenin stilini ayrı ayrı ayarlar. |
border-width | Kısaltma özelliği, elemanın tüm çerçevelerinin genişliğini ayarlar veya her kenar çerçevenin genişliğini ayrı ayrı ayarlar. |
border-color | Kısaltma özelliği, elemanın tüm çerçevelerinin görünür kısmının rengini ayarlar veya dört kenara ayrı ayrı renk ayarlar. |
border-bottom | Kısaltma özelliği, alt çerçevenin tüm özelliklerini bir bildiride birleştirmek için kullanılır. |
border-bottom-color | Elemanın alt çerçeve rengini ayarlayın. |
border-bottom-style | Elemanın alt çerçeve stilini ayarlayın. |
border-bottom-width | Elemanın alt çerçeve genişliğini ayarlayın. |
border-left | Kısaltma özelliği, sol çerçevenin tüm özelliklerini bir bildiride birleştirmek için kullanılır. |
border-left-color | Elemanın sol çerçeve rengini ayarlayın. |
border-left-style | Elemanın sol çerçeve stilini ayarlayın. |
border-left-width | Elemanın sol çerçeve genişliğini ayarlayın. |
border-right | Kısaltma özelliği, sağ çerçevenin tüm özelliklerini bir bildiride birleştirmek için kullanılır. |
border-right-color | Elemanın sağ çerçeve rengini ayarlayın. |
border-right-style | Elemanın sağ çerçeve stilini ayarlayın. |
border-right-width | Elemanın sağ çerçeve genişliğini ayarlayın. |
border-top | Kısaltma özelliği, üst çerçevenin tüm özelliklerini bir bildiride birleştirmek için kullanılır. |
border-top-color | Elemanın üst çerçeve rengini ayarlayın. |
border-top-style | Elemanın üst çerçeve stilini ayarlayın. |
border-top-width | Elemanın üst çerçeve genişliğini ayarlayın. |
- Önceki Sayfa CSS İç Kenar Boşluğu
- Sonraki Sayfa CSS Kenar Boşluğu