Sass’ın temel yazım kurallarından biriside iç içe (nested) kullanımdır. CSS ile kod yazarken girintiler çok önemli değildir. Biz daha iyi bir düzen için girintileme yapıyorduk ama bu girintiler CSS için bir şey ifade etmiyordu. Sass’ta ise girintilerin bir anlamı ve işlevi var.
CSS ile kod yazarken ebeveyn ve çocuk seçicileri ilişkilerini ve seçici önem sırasını düzenlemek için kodlarımızda aşağıdaki gibi bir düzen kuruyorduk.
Genel bir menü kodu:
yukarıda basit bir menü kodunu nasıl yazdığımızı gösterdik. Kodu incelediğimizde her satır ebeveyn ve çocuk seçicileri iletişimini belirtmek durmundayız. Sass burada çok güzel bir hareket yapıyor ve bu tekrardan bizi kurtarıyor. Yukarıdaki kodu Sass ile yazalım.
daha kolay yazım, temiz görünüm ve anlaşılır kod. İlk seçici solda dururken çocuk seçicileri bir sekme (tab) içerden başlayacak şekilde kodluyoruz.
Sözde sınıf ve elementleri ise ve imi (&) ile bitişik yazıyoruz. &:hover, &:before, &:first-child vd.
Ben bir sekmeyi 4 boşluk olacak şekilde kullanıyorum. 2 olarak kullanan da var. İki olarak kullananların kodu bana çok karışık geliyor.
Çok fazla iç içe seçici kullanımı kod okunurluğunu azaltıyor. Çözüm olarak bence bir prensip kararı alıp dört iç içe sekmede kendimizi sınırlamalıyız.
Böyle bir karar alıp uygulamak projelerinizde sizi rahatlatacaktır.
Ve imi (&) ile ebeveyn seçicisi
Sass ve imi (&) ile ebeveyn seçicisini referans alan bir yapıyı destekler. CSS’te bir çok defa aradığımız bir özellik olan ebeveyn seçme işi Sass sayesinde erişme imkanımız var.
CSS kodu;
İnternet Explorer 8 sürümünde margin sorunumuz olduğunu düşünün. CSS ile bu sorunu aşmak için altında veya ayrı bir dosyaya yazıyoruz. Bu kontrolü zorlaştırıyordu. Sass’daki kullanım ile daha derli toplu çözüm oluşturmuş oluruz. Bir çok kullanım yerinin olduğu ebeveyn seçicisi süper bir artı özellik.
Kardeş seçicisi
Genel kardeş ve bitişik kardeş seçicisi için
gibi yazıldığı gibi.
şeklindeki yazımı da Sass destekler. Benzer şekilde ~, > kullanılabilir.
BEM kullanımı
BEM benzeri seçici kullanımını Sass 3.3’den sonra desteklemektedir.
BEM, CSS seçicilerini isimlendirme ve sınıflandırma için kullanılan çok daha kesin, şeffaf ve bilgilendirici bir yöntemdir.
Şeklinde bir örnek daha açıklayıcı olur. Burada Sass’ın avantajı
Tekrarlardan kurtulmuş oluyoruz. Ben bu kullanımda şöyle bir sorun yaşadım: Seçicileri bulmak sıkıntı oluyor. Aramak zorlaşıyor.
İç içe özellik kullanımı
Yukarıdaki gibi iç içe seçici kullanımı benzeri iç içe özellik kullanımında da vardır.
Sass ile yazarken
Seçicilerde olduğu gibi tekrarlardan kurtulmuş oluruz.
Kalın sağlıcakla.
Kaynaklar
- http://sass-lang.com/guide
- http://sass-lang.com/documentation/file.INDENTED_SYNTAX.html
- thesassway.com/beginner/the-inception-rule
- http://leveluptuts.com/tutorials/sass-tutorials/3-nesting-your-sass
- http://wibblystuff.blogspot.com.tr/2014/12/a-better-approach-to-nesting-in-sass.html
- https://viget.com/extend/organizing-nested-selectors-in-sass
- http://blog.teamtreehouse.com/sass-tip-double-ampersand-selector
- http://markdotto.com/2015/07/20/css-nesting/
- http://www.sitepoint.com/sass-basics-nesting/
- http://www.sitepoint.com/beware-selector-nesting-sass/
- http://www.yunusbassahan.com/blog/sass/ic-ice-secici-kullanimi-nesting.html
- http://sonsuzdongu.com/blog/sass-a-giris
- github.com/rssems/CSS-Rehberi
- http://mrhaki.blogspot.com.tr/2013/02/sass-snippets-compact-syntax-for-nested.html