Tasarım sistemlerinde ve bileşen kitaplıklarında Özel Mülk kullanmanın avantajları.
Adım Dave, Nordhealth'te Kıdemli Kullanıcı Arabirimi Geliştiricisiyim. Bileşen kitaplığımız için Web Bileşenleri oluşturmayı içeren tasarım sistemimiz Nord'un tasarımı ve geliştirilmesi üzerinde çalışıyorum. CSS Özel Özellikleri'ni kullanarak Web Bileşenleri'nin stil özelliklerini ayarlamayla ilgili sorunları nasıl çözdüğümüzü ve tasarım sistemlerinde ve bileşen kitaplıklarında Özel Özellikleri kullanmanın diğer bazı avantajlarını sizinle paylaşmak istiyorum.
Web Bileşenlerini nasıl oluştururuz?
Web Bileşenlerimizi oluşturmak için durum, kapsamlı stiller ve şablon gibi çok sayıda standart kod sağlayan Lit kitaplığını kullanıyoruz. Lit hafif olmakla kalmaz, aynı zamanda yerel JavaScript API'leri üzerine de geliştirilmiştir. Böylece, tarayıcının sahip olduğu özelliklerden yararlanan yalın bir kod paketi sunabiliriz.
Ancak Web Bileşenlerinin en çekici yanı, hemen hemen tüm mevcut JavaScript çerçeveleriyle, hatta hiç çerçeveyle çalışmamalarıdır. Sayfada ana JavaScript paketi referans gösterildikten sonra Web Bileşeni kullanımı, yerel bir HTML öğesinin kullanılmasına çok benzer. Bunun yerel bir HTML öğesi olmadığını söyleyen tek gerçek işaret, etiketlerde yer alan tutarlı kısa çizgidir. Bu, tarayıcıya bunun bir Web Bileşeni olduğunu belirtmek için kullanılan bir standarttır.
Gölge DOM stili kapsülleme
Yerel HTML öğelerinin bir Gölge DOM'una sahip olması gibi, Web Bileşenleri de bu işleve sahiptir. Gölge DOM, bir öğe içindeki gizli bir düğüm ağacıdır. Bunu görselleştirmenin en iyi yolu, web denetleyicinizi açıp "Gölge DOM ağacını göster" seçeneğini etkinleştirmektir. Bunu yaptıktan sonra, denetleyicide yerel bir giriş öğesine bakmayı deneyin. Artık bu girişi açıp içindeki tüm öğeleri görme seçeneğiniz olacaktır. Bunu Web Bileşenlerimizden biriyle bile deneyebilirsiniz. Gölge DOM'yi görmek için özel giriş bileşenimizi incelemeyi deneyin.
Gölge DOM'un avantajlarından (veya bakış açınıza bağlı olarak dezavantajlarından) biri stil kapsüllemedir. Web Bileşeninizin içinde CSS yazarsanız, bu stiller sızdırılamaz ve ana sayfayı veya diğer öğeleri etkilemez. Bunlar tamamen bileşenin içinde yer alır. Ayrıca, ana sayfa veya bir üst Web Bileşeni için yazılan CSS, Web Bileşeninize sızdıramaz.
Stillerin bu şekilde bir araya getirilmesi, bileşen kitaplığımızın avantajlarından biridir. Böylece, bir kullanıcı bileşenlerimizden birini kullandığında, üst sayfaya uygulanan stillerden bağımsız olarak içeriğin istediğiniz gibi görüneceğini daha fazla garanti ederiz. Daha da emin olmak için tüm Web Bileşenlerimizin kök veya "barındırıcısına" all: unset;
ekliyoruz.
Ancak Web Bileşeninizi kullanan birinin belirli stilleri değiştirmek için geçerli bir nedeni varsa ne olur? Belki bağlamı nedeniyle daha fazla kontrast gerektiren bir metin satırı vardır veya bir kenarlığın daha kalın olması gerekir? Bileşeninize stil giremiyorsa bu stil seçeneklerinin kilidini nasıl açabilirsiniz?
CSS Özel Mülkleri burada devreye girer.
CSS Özel Özellikleri
Özel Mülkler oldukça uygun bir şekilde adlandırılmıştır. Tamamen kendiniz adlandırabileceğiniz ve gereken değeri uygulayabileceğiniz CSS özellikleridir. Tek şart, önlerine iki kısa çizgi koymanızdır. Özel mülkünüzü tanımladıktan sonra değer, var()
işlevi kullanılarak CSS'de kullanılabilir.
Devralma söz konusu olduğunda, tüm Özel Mülkler devralınır. Bu da normal CSS mülklerinin ve değerlerinin tipik davranışını izler. Bir üst öğeye veya öğenin kendisine uygulanan herhangi bir özel özellik, diğer mülklerde değer olarak kullanılabilir. Özel Özellikleri, CSS çerçevemiz aracılığıyla kök öğeye uygulayarak tasarım jetonlarımız için yoğun bir şekilde kullanırız. Diğer bir deyişle, ister bir Web Bileşeni, ister CSS yardımcı sınıfı ister jeton listemizden bir değer çıkarmak isteyen bir geliştirici olsun, sayfadaki tüm öğeler bu jeton değerlerini kullanabilir.
Web Bileşenlerinin Gölge DOM'sini devirme ve geliştiricilerin bileşenlerimizin stilini belirlerken daha hassas bir kontrole sahip olmasını sağlamak için var()
işlevini kullanarak Özel Özellikleri devralma olanağını kullanıyorduk.
Bir Nord Web Bileşenindeki Özel Mülkler
Tasarım sistemimizin bir bileşenini geliştirirken, CSS'ye ilişkin düşünceli bir yaklaşım benimsiyoruz. Böylece yalın ve bakımı kolay bir kod oluşturmayı amaçlıyoruz. Tasarım jetonları, kök öğedeki ana CSS Çerçevemizde Özel Mülkler olarak tanımlanır.
Daha sonra bu jeton değerlerine bileşenlerimizde başvurulur. Bazı durumlarda, değeri doğrudan CSS mülküne uygularız ancak bazılarında, bazen yeni bir içeriğe dayalı Özel Mülk tanımlar ve değeri buna uygularız.
Ayrıca, bileşene özgü olan ancak jetonlarımızda bulunmayan bazı değerleri soyutlayarak bunları bağlamsal bir Özel Mülk'e dönüştüreceğiz. Bileşene dayalı özel mülkler bize iki önemli avantaj sağlar. İlk olarak, bu değer bileşenin içindeki birden fazla özelliğe uygulanabileceğinden CSS'mizde daha "kritik" olabileceğimiz anlamına gelir.
İkinci olarak, bileşen durumu ve varyasyon değişikliklerini gerçekten açık hale getirir. Örneğin, bir fareyle üzerine gelme veya etkin durumun stilini oluştururken ya da bu örnekte varyasyon oluştururken tüm bu özelliklerin güncellenmesi için yalnızca özel özelliğin değiştirilmesi gerekir.
Ancak en büyük faydası, bir bileşende bu bağlamsal Özel Özellikler'i tanımladığımızda, her bileşenimiz için söz konusu bileşenin kullanıcısı tarafından kullanılabilen bir tür özel CSS API'sı oluşturmamızdır.
Yukarıdaki örnek, bağlamsal bir özel mülkü olan Web Bileşenlerimizden birinin seçici aracılığıyla değiştirildiğini göstermektedir. Bu yaklaşımın bütünüyle, gerçek stillerin büyük bir kısmını kontrol altında tutarken kullanıcıya yeterli stil esnekliği sunan bir bileşen ortaya çıkar. Ayrıca, bileşen geliştiricileri olarak kullanıcı tarafından uygulanan bu stilleri engelleme olanağına da sahibiz. Bu özelliklerden birini ayarlamak veya genişletmek istediğimizde, kullanıcının kodlarında herhangi bir değişiklik yapmasına gerek kalmadan bunu yapabiliriz.
Bu yaklaşımın, yalnızca tasarım sistemi bileşenlerinin yaratıcıları olarak bizim için değil, bu bileşenleri ürünlerimizde kullanan geliştirme ekibimiz için de son derece güçlü olduğunu düşünüyoruz.
Özel Mülkler'i daha ileri taşıma
Bu bağlamsal Özel Mülkleri, yazıldığı sırada belgelerimizde açıklayamıyoruz. Ancak, daha kapsamlı geliştirme ekibimizin bu mülkleri anlayıp yararlanabilmesi için bunu yapmayı planlıyoruz. Bileşenlerimiz, hakkında bilmeniz gereken her şeyi içeren bir manifest dosyası ile npm'de paketlenir. Daha sonra, dokümantasyon sitemiz dağıtıldığında manifest dosyasını veri olarak kullanırız. Bu işlem, Eleventy'yi ve Global Veri özelliğini kullanarak yapılır. Bağlamsal Özel Mülkleri, bu manifest veri dosyasına eklemeyi planlıyoruz.
Geliştirmek istediğimiz bir başka alan da bu içeriğe dayalı Özel Mülklerin değerleri devralmasıdır. Şu anda, örneğin iki ayırıcı bileşenin rengini ayarlamak istiyorsanız özellikle seçicilerle bu bileşenlerin ikisini de hedeflemeniz veya özel özelliği doğrudan style özelliğine sahip öğeye uygulamanız gerekir. Bu seçenek iyi gibi görünebilir, ancak geliştirici bu stilleri kapsayıcı öğede veya kök düzeyinde tanımlayabilirse daha faydalı olur.
Özel Mülk değerini doğrudan bileşen üzerinde ayarlamanızın nedeni, aynı öğede bileşen ana makine seçici aracılığıyla bunları tanımlıyor olmamızdır. Doğrudan bileşende kullandığımız genel tasarım jetonları doğrudan geçer, bu sorundan etkilenmez ve üst öğelerde bile ele geçirilebilir. Her iki platformdan da en iyi şekilde yararlanmak için neler yapabiliriz?
Özel ve herkese açık Özel Mülkler
Özel özel mülkler Lea Verou tarafından derlenen bir yapıdır. Lea Verou, bileşenin kendisinde içeriğe dayalı "gizli" bir Özel Mülk olup, yedekli "herkese açık" bir Özel Mülk olarak ayarlanmıştır.
İçeriğe dayalı Özel Mülklerimizi bu şekilde tanımlamak, global jeton değerlerini devralma ve değerleri bileşen kodumuz genelinde yeniden kullanma gibi daha önce yaptığımız tüm işlemleri yapabildiğimiz anlamına gelir. Ancak bileşen, kendi üzerinde veya herhangi bir üst öğede söz konusu mülkün yeni tanımlarını da incelikle devralacaktır.
Bu yöntemin gerçekten "gizli" olmadığı düşünülse de, bu yöntemin endişe ettiğimiz bir sorun için oldukça şık bir çözüm olduğunu düşünüyoruz. Fırsat bulduğumuzda bu sorunu bileşenlerimizde ele alacağız. Böylece geliştirme ekibimiz hem bileşen kullanımı üzerinde daha fazla kontrole sahip olur hem de uygulanmakta olan güvenlik önlemlerinden yararlanmaya devam eder.
CSS Özel Mülkleri ile Web Bileşenleri'ni nasıl kullandığımıza dair bu bilgiyi yararlı bulduğunuzu umuyoruz. Düşüncelerinizi bizimle paylaşabilirsiniz. Bu yöntemlerden herhangi birini kendi çalışmanızda kullanmaya karar verirseniz beni Twitter'da @DavidDarnes adresinden bulabilirsiniz. Ayrıca, bu tasarım sistemini bir araya getirmek ve bu makalede bahsedilen özellikleri uygulamak için büyük emek veren ekip arkadaşlarımın yanı sıra @NordhealthHQ Twitter'da da Twitter'da bulabilirsiniz: @Viljamis, @WickyNilliams ve @eric_habich.