*ngFor ile trackby kullanımı

Angular performans ipuçları

0 1,797

Angular’da var olan listemizi HTML sayfamızda göstermek için *ngForkullanırız. Kullandığımız liste (array) değiştiğinde(örneğin; servisten son hali tekrar yüklendiğinde); liste gösterimi için oluşturulan tüm DOM tekrar güncellenmektedir. Eğer liste boyutu büyük ise tüm DOM’un yüklenmesi performans sorunu yaratabilir. Bu durumun önüne nasıl geçeriz diyorsanız beni takip edin.

İçindekiler:
Bu Makalede aşağıdaki konuları içerecektir
* Proje Senaryosu
* Proje hazırlık.
* trackBy nedir? Ne işe yarar?
* Sonuç
* Proje Kodları (Github Repository)

Öğrenci İşleri

trackBy fonksiyonunun anlaşılması için çok çok çok küçük bir öğrenci işleri uygulaması yapacağız. Uygulamamızda sınava giren, erkek ve kız öğrencilerin numarası, adı ve notlarını ekranda gösterilecek. Not girme işlemi devam ettiği için kullanıcı butona basarak not bilgisi girilen yeni öğrenci bilgisini ekranda gösterilecek. Uygulamamız küçük olduğu için ilk başta 3 kız ve 3 erkek öğrenci bilgisi ekranda görüntülenecek. Kullanıcı butona bastığında listeye eklenen 1 erkek ve 1 kız öğrenci bilgisi de ekranda gösterilecek.

Projemizi oluşturuyoruz

Her zaman olduğu gibi; Angular CLI kullanarak projemizi oluşturmakla başlıyoruz

Bilgisayarınızda Visual Studio Code ve node.js yüklü olmalı. Eğer yüklü değilse Visual Studio Code için burayı, Node.js için burayı tıklayın

Visual Studio Codeyi açtıktan sonra terminale aşağıdaki kodu yazarak yeni projemizi yaratıyoruz

Bu işlemin sonucunda proje yapımız şu şekilde olacak.

Resim-1: Proje Yapısı

trackBy nedir? Ne işe yarar?

trackBy fonksiyonu ile listenizde sadece değişen elemanlar için DOM yüklemesi yapar. trackBy fonksiyonu tekil (unique) bir özellik (bu tekillik listemizde bulunan tekil id, adi v.b. bir nesne olmalı) üzerinden çalışır. trackBy listemizin elemanlardan sadece değişenler için çalışacaktır.

Örneğin listemizde tekil olarak id ve değişen bir ad nesnemiz olsun. *ngFor ile kullandığımız, Listemiz; [{id: 1, ad: ‘Ali’},{id:2, adi: ‘Ahmet’}]şeklinde olsun. Eğer listemiz servisten [{id: 1, ad: ‘Ali’},{id:2, adi: ‘Ahmet’}, {id:3, adi: ‘Aytuç’}] şeklinde güncellenirse, DOM’da sadece listemizin 3. elamanı için güncelleme yapılacak. Eğer listemiz [{id: 1, ad: ‘Ali’},{id:2, adi: ‘Akif’}, {id:3, adi: ‘Aytuç’}] olarak güncellenirse DOM’da sadece 2 ve 3 nolu elemanlar için güncelleme yapılacak.

“app.component.ts” dosyamızı açarak aşağıdaki işlemleri yapıyoruz. erkekOgrenciler listesi ile ngFor ile trackBy özelliğini kullanmayacağız. kizOgrenciler ile ngFor ile trackBy kullanacağız. getErkekOgrenciler() ve getKizOgrenciler() metodu öğrencilerin yeni listesini getiren servis gibi kullanacağız. Her iki metotta listeye yeni bir öğrenci ekleniyor. Öğrencilerin notları liste yenilendikçe rastgele olarak tekrar belirlenmektedir.

trackByFn(index: number, kisi) metodu ile trackBy için kullanılacaktır. Bu metotta id nesnesi tekil alan olarak kullanılmıştır(31. satır). Eğer başka tekil bir alan varsa o da kullanılabilir. Öğrenci işleri uygulamamız için name özelliği’de tekil alan olduğu için bu nesne de kullanılabilir.

“app.component.html” dosyasını açıp aşağıdaki işlemleri yapıyoruz. HMTL dosyasında erkek ve kız öğrencileri notları olmadan ve notları olacak şekilde gösteriyoruz. Erkek öğrenciler için ngFor’da trackBy kullanmıyoruz(satır: 8 ve 13). Satır 8’de erkek öğrencilere ait not bilgisi gösterilmiyor. Satır 13’de ise erkek öğrencilerin not bilgisi de gösteriliyor. Kız Öğrenciler için ngFor’da trackBy kullanıp “app.component.ts” de tanımladığımız trackByFnfonksiyonunu atıyoruz (satır: 18 ve 23). Satır 18’de kız öğrencilere ait not bilgisi gösterilmiyor. Satır 23’de ise kız öğrencilerin not bilgisi de gösteriliyor.

SONUÇ:

 

Kullanıcı “Erkek Öğrencileri Güncelle” butona 2 kere tıklıyor. Her tıklamada not bilgisi olmayan ve olan listelere ait olan DOM her seferinde tekrardan güncelleniyor.

Kullanıcı daha sonra “Kız Öğrencileri Güncelle” butona 4 kez basıyor. Not bilgisinin olmadığı listeye ait olan DOM sadece 1 kez güncelleniyor. Not bilgisinin ait olduğu listede ise sadece not bilgisi değişen öğrenciler ve yeni eklenen kız öğrenciler için DOM bilgisi güncelleniyor.

Makalenin kaynak kodları:

 

 

 

 

 

Email adresiniz yayınlanmayacaktır.