DEV Community

Eray Kaya
Eray Kaya

Posted on

Reduce'u nasıl kullanabiliriz?

Herkese merhaba tekrar, ilk yazımda reduce metodunun nasıl çalıştığını incelemiştik. Şimdi de örneklerle nasıl kullanabileceğimize bakalım.

Öncelikle en çok kullanıldığı alan olan; array içindeki değerleri toplama işlemini reduce'la nasıl yapabileceğimize bakalım.

Bir önceki yazmızdan hatırlayacağımız gibi callback fonksiyonumuzun aldığı değerler accumulator, anlık değer, index ve array'di. İlk değer belirtilmediği için otomatik olarak ilk eleman olan 1 ile başladık.

Burada şu mantıkla düşünebiliriz:

ilk değer(initialValue): 1

accumulator = ilk değer

ilk iterasyon: accumulator = accumulator + 2
accumulator şu an 3'e eşit

ikinci iterasyon: accumulator = accumulator + 3
accumulator şu an 6'ya eşit

Fonksiyon accumulator'ı döndürdüğü için sonuç 6'ya eşit.

const sum = [1, 2, 3].reduce((acc, cur) => acc + cur);

console.log(sum);
// 6
Enter fullscreen mode Exit fullscreen mode

Gelelim biraz daha karmaşık olabilecek örneklerimize:

Öncelikle veri yapımızı buraya bırakacağım unutmayın bütün örneklerde aynı veri yapısını kullanacağınız:

const users = [{
        id: "124124124124",
        name: "Some Person",
        username: "some123",
        insterests: ["hiking", "sports"],
        country: {
            code: "tr",
            name: "Turkey"
        }
    },
    {
        id: "456456",
        name: "John Doe",
        username: "john123",
        insterests: ["sci-fi", "coding"],
        country: {
            code: "us",
            name: "United States"
        }
    },
    {
        id: "56356456",
        name: "Foo Bar",
        username: "foo123",
        insterests: ["board games"],
        country: {
            code: "de",
            name: "Germany"
        }
    },

]
Enter fullscreen mode Exit fullscreen mode

İlk örneğimizde bu array yapısındaki veri yapısını nasıl istediğimiz key - value ikilisini kullanarak objeye çevirebileceğimize bakacağız:

Bu noktada sistem şu şekilde çalışacak:
ilk değerimiz: {} //boş bir obje;
accumulator = {}

ilk iterasyon: accumulator[124124124124] = 'Some Person'
accumulator = {124124124124: 'Some Person'}

ikinci iterasyon: accumulator[456456] = 'John Doe'
accumulator = {124124124124: 'Some Person', 456456: 'John Doe'}

üçüncü iterasyon: accumulator[56356456] = 'Foo Bar'
accumulator = {124124124124: 'Some Person', 456456: 'John Doe', 56356456: 'Foo Bar'}

 const reducedArr = users.reduce((accumulator, currentValue) => {
    accumulator[currentValue.id] = currentValue.name;
    return accumulator;
  }, {});

Enter fullscreen mode Exit fullscreen mode

Diğer örneğimizde ise veri yapısı aynı kalacak şekilde istediğimiz key value eşlerini arrayin içine koyacağız.

Burada da sistem şu şekilde çalışır:

ilk değerimiz: []
accumulator = []

Burada spread syntax kullanılmıştır basitçe anlatmak gerekirse:

const arr = []; const arr2 = [...arr, {name: 'random'}] console.log(arr2) = [{name: 'random'}] şeklinde çalışır.

ilk iterasyon: accumulator = [{name: 'Some Person', id: '124124124124'}]
.
.
.


 const nameById = users.reduce((accumulator, currentValue) => {
    accumulator = [...accumulator, {name: currentValue.name, id: currentValue.id}];
    return accumulator
 }, []) 

Enter fullscreen mode Exit fullscreen mode

Yukarıda oluşturduğumuz arrayi yine aynı mantıkla fakat ilk kullandığımız array için keylerle de oluşturabilirdik:

 const nameById = users.reduce((accumulator, currentValue) => {
    accumulator = [...accumulator, {[currentValue.id]: currentValue.name}];
    return accumulator
 }, []) 

Enter fullscreen mode Exit fullscreen mode

Genel olarak reduce metodunu bu şekilde kullanabilirsiniz.

Daha başka hangi konularda yazı gelmesini istiyorsanız yorumlarda belirtebilirsiniz.

Top comments (0)