Yalnızca Oluşturucu Özelliklerini Kullanın ve Katman Sayısını Yönetin

Paul Lewis

Birleştirme, sayfanın boyanmış bölümlerinin ekranda gösterilmek üzere bir araya getirildiği işlemdir. Birleştirilmemiş animasyonlar daha fazla çalışma gerektirir ve düşük kaliteli telefonlarda veya ana iş parçacığında performans açısından yoğun görevler yürütüldüğünde kalitesiz (sürükleyici olmayan) görünebilir.

Bu alanda sayfa performansını etkileyen iki önemli faktör vardır: yönetilmesi gereken kompozisyon katmanlarının sayısı ve animasyonlar için kullandığınız özellikler.

  • Animasyonlarınızda dönüşüm ve opaklık değişikliklerini kullanın.
  • will-change veya translateZ ile hareketli öğeleri öne çıkarın.
  • Promosyon kurallarını aşırı kullanmaktan kaçının. Katmanlar bellek ve yönetim gerektirir.

Animasyonlar için dönüşüm ve opaklık değişikliklerini kullanma

Piksel ardışık düzeninin en iyi performans gösteren sürümü hem düzenden hem de boyamadan kaçınır ve yalnızca kompozisyon değişiklikleri gerektirir:

Düzen veya boya içermeyen piksel ardışık düzeni.

Bunu başarmak için yalnızca derleyici tarafından yönetilebilecek özellikleri değiştirmeniz gerekir. Şu anda bu durum yalnızca transform ve opacity mülkleri için geçerlidir:

Düzen veya boya tetiklemeden animasyon oluşturabileceğiniz özellikler.

transform ve opacity kullanımıyla ilgili uyarı, bu özellikleri değiştirdiğiniz öğenin kendi kompozisyon katmanında olması gerektiğidir. Katman oluşturmak için öğeyi tanıtmanız gerekir. Bu konuyu bir sonraki bölümde ele alacağız.

Animasyon eklemeyi planladığınız öğeleri öne çıkarma

"Boya karmaşıklığını basitleştirme ve boya alanlarını azaltma" bölümünde de belirttiğimiz gibi, animasyonlu hale getirmeyi planladığınız öğeleri (aşırıya kaçmadan) kendi katmanlarına taşımanız gerekir:

.moving-element {
  will-change: transform;
}

Eski tarayıcılar veya will-change özelliğini desteklemeyen tarayıcılar için:

.moving-element {
  transform: translateZ(0);
}

Katmanları yönetme ve katman patlamalarından kaçınma

Katmanların genellikle performansa yardımcı olduğunu bildiğiniz için sayfanızdaki tüm öğeleri aşağıdaki gibi bir öğeyle tanıtmak cazip gelebilir:

* {
  will-change: transform;
  transform: translateZ(0);
}

Bu, sayfadaki her bir öğeyi tanıtmak istediğinizi dolaylı bir şekilde ifade eder. Buradaki sorun, oluşturduğunuz her katmanın bellek ve yönetim gerektirmesi ve bunun ücretsiz olmamasıdır. Hatta, sınırlı belleğe sahip cihazlarda performans üzerindeki etkisi, katman oluşturmanın avantajlarından çok daha ağır basabilir. Her katmanın dokularının GPU'ya yüklenmesi gerekir. Bu nedenle, CPU ile GPU arasındaki bant genişliği ve GPU'daki dokular için kullanılabilen bellek açısından başka kısıtlamalar vardır.

Uygulamanızdaki katmanları anlamak için Chrome Geliştirici Araçları'nı kullanma

Chrome Geliştirici Araçları'ndaki boya profilleyicinin açma/kapatma düğmesi.

Uygulamanızdaki katmanları ve bir öğenin neden katmana sahip olduğunu anlamak için Chrome Geliştirici Araçları'nın Zaman Çizelgesi'nde Boya profilleyiciyi etkinleştirmeniz gerekir:

Bu ayarı etkinleştirdikten sonra kayıt almalısınız. Kayıt tamamlandığında, saniyedeki kare sayısı çubukları ile ayrıntılar arasında bulunan kareleri tek tek tıklayabilirsiniz:

Geliştiricinin profil oluşturmak istediği bir çerçeve.

Bunu tıkladığınızda ayrıntılar bölümünde yeni bir seçenek gösterilir: katman sekmesi.

Chrome Geliştirici Araçları'ndaki katman sekmesi düğmesi.

Bu seçenek, ilgili karedeki tüm katmanları kaydırmanıza, taramanıza ve yakınlaştırmanıza olanak tanıyan yeni bir görünüm açar. Ayrıca her katmanın oluşturulma nedenini de gösterir.

Chrome Geliştirici Araçları'ndaki katman görünümü.

Bu görünümü kullanarak sahip olduğunuz katman sayısını izleyebilirsiniz. Kaydırma veya geçişler gibi performans açısından kritik işlemler sırasında çok fazla zaman harcıyorsanız (4-5 ms civarında bir süreyi hedeflemeniz gerekir) kaç katmanınız olduğunu ve bunların neden oluşturulduğunu görmek için buradaki bilgileri kullanabilir ve buradan uygulamanızdaki katman sayılarını yönetebilirsiniz.