CSS ile web sayfası kodlarken bizi en çok zorlayan konulardan biri daha önceki yazılarımda bahsettiğim gibi farklı tarayıcı sürümlerine göre kod yazmaktır. CSS ile kod yazarken bazı durumlarda kodumuz bir tarayıcı grubunda düzgün görünürken başka bir tarayıcı grubunda farklı görüntülenir, tabi biz yaptığımız sitelerin kullanıcılar tarafından tarayıcısı ne olursa olsun aynı görünmesini isteriz. Bu gibi durumlarda kullandığımız yöntem aslında çok basit bir tekniktir. Hangi tarayıcıda farklı görünüyorsa onun için farklı kod yazarız ve bunu diğer tarayıcıların görmeyeceği kod bloğu içinde yazarız.
CSS Derslerindeki CSS Sorunları ve Çözüm Önerileri kısmındaki birçok yöntemin ana mantığıda budur.
Farklı tarayıcılar için düzenleme(hack) yazarken genel anlamda iki farklı yöntem kullanırız. Farklı css dosyaları hazırlayıp bunları eklerken şartlı yorumlar yardımı ile farklı tarayıcılar için farklı css kodlarını gösteririz, ikinci yöntem ise kod içerisinde o tarayıcının gördüğü kod bloğu içinde ona göre kod yazarız. Burada birinci yöntemi(IE?de Hata Ayıklamak için şartlı Yorumlar Kullanmak) daha önce anlatmıştık. Bu yazımızda kod içindeki css düzeltmelerinden bahsedeceğiz.
CSS kodu içinde farklı tarayıcılar için farklı kod yazmanın en kolay yolu, tarayıcılara özel seçiciler içine kod yazmaktır.
Tarayıcılara Özel Seçiciler
IE 6 ve altı
IE 7 ve altı
1 |
*:first-child+html {} * html {} |
sadece IE 7 için
IE 7 ve yeni nesil tarayıcılar için
Yalnız yeni nesil tarayıcılar için (IE 7 dışında)
Opera 9 ve altı sürümler için
Safari
1 |
html[xmlns*= "" ] body:last-child {} |
Google Chrome and Safari 3.1
Firefox 2
1 |
.foo, x:-moz-any-link { } |
FireFox 3
1 |
.foo, x:-moz-any-link, x: default { } |
Firefox 2 ve 3 için yazdığımız kodu ie 7 de yorumluyor bunu engellemek için (Sonradan eklenmiştir.)
1 |
.foo, x:-moz-any-link { } |
2 |
.foo, x:-moz-any-link, x: default { } |
3 |
*:first-child+html .foo{} |
Sadece Firefox 3
1 |
html>; body .foo, x:-moz-any-link, x: default { } |
Burada önemli olan her tarayıcı farklı görünümünde bu metoda başvurmamak gerekir, çözümü olmayan sorunlarla karşılaştığımızda bu kodları kullanmalıyız.
Bu kodları kullanma gereksinim genelde Internet Explorer 6 ve 7 için oluyor. Ama nadirende olsa diğer tarayıcıların düzeltmeleride lazım oluyor. Bir örnek yapalım
02 |
.ozelSecici, x:-moz-any-link { |
03 |
background-color : #ffd560 ; |
06 |
.ozelSecici, x:-moz-any-link { |
07 |
background-color : #ab1b0b ; |
10 |
.ozelSecici, x:-moz-any-link, x: default { |
11 |
background-color : #e6831f ; |
14 |
body:nth-of-type( 1 ) .ozelSecici{ |
15 |
background-color : #e6f0fa ; |
18 |
html:first-child .ozelSecici{ |
19 |
background-color : #a91614 ; |
22 |
*:first-child+html .ozelSecici{ |
23 |
background-color : #0098de ; |
26 |
*:first-child+html .ozelSecici{ |
27 |
background-color : #d4d0c8 ; |
30 |
background-color : #d4d0c8 ; |
34 |
background-color : #996666 ; |
HTML kodu
1 |
< p class = "ozelSecici" >Tarayıcı</ p > |
Örneği görmek için tıklayınız.
Aynı XHTML kodu için aşağıdaki gibi farklı tarayıcılarda farklı sonuçları alırız.
Sayfa Google Chrome 0.3.154.9, Safari 3.1.2, Firefox 3.0.4/2.0.0.14, Internet Explorer 7/6/5.5, Opera 9.6 ile test edilmiştir.
Kaynak : CSS Dersleri, Fatih HAYRİOĞLU