Vuex Store - Mutations Kavramı ve Anlatımı
Bir Vuex mağazasında State üzerindeki veriyi değiştirmenin tek yolu bir mutasyon gerçekleştirmektir. Mutasyon içerisinde bir fonksiyon oluşturduğumuzda State'i ilk argüman olarak alır:
const store = new Vuex.Store({
state: {
miktar: 1
},
mutations: {
artir (state) {
// State üzerindeki "miktar"ı güncelle
state.miktar++
}
}
})
Bir mutasyonu doğrudan nesne adı ile çağıramazsınız. Bunun için store.commit("") fonksiyonunu çağırmanız gerekir.
store.commit('miktar')
Veriyi Commit Etmek
Store.commit'e payload(güncelleyeceğiniz veri) olarak adlandırılan ek bir bağımsız değişken iletebilirsiniz:
mutations: {
increment (state, payload) {
state.miktar += payload.sayi
}
}
Payload güncel olarak değişim yapacağınız data'dır.
store.commit('artir', {
sayi: 10
})
Nesne Tarzında Commit Yapmak
Bir mutasyonu gerçekleştirmenin alternatif bir yolu, type özelliği olan bir nesneyi doğrudan kullanmaktır:
store.commit({
type: 'artir',
sayi: 10
})
Yukarıda commit() içerisine sadece bir nesne ekledik ve daha önce birinci parametrede belirttiğimiz mutasyon adını bu sefer type değeri ile ekledik. Vuex de adı type üzerinden aldı. Bu durum mutasyonun daha önceki yapısı üzerinde de bir değişiklik yapmanızı gerektirmez. Yani aynı işlemi yapmış olduk.
Mutasyonların nasıl işlediğine ve kullanıldığına değindik. Mutasyon kullanımını üç farklı makalede ele alacağız. Bir sonrakinde Vue'nun reaktivite sisteminin Mutasyonlar üzerindeki etkisini inceleyeceğiz.
0 yorum:
Yorum Gönder