Vuex Store - Mutations ve Vue.js Reaktivitesi
Mutasyonların Vue'nun Reaktivite Kurallarına Uyması
Bir Vuex mağazasının state'i Vue tarafından reaktif hale getirildiğinden, state üzerinde değişiklik yaptığınızda durumu gözlemleyen Vue bileşenleri otomatik olarak güncellenecektir. Bu aynı zamanda Vuex mutasyonlarının düz Vue ile çalışırken aynı reaktivite uyarılarına tabi olduğu anlamına gelir.
Yani CLI üzerinden değil de, web üzerinde kullanmış olduğunuz Vue örneği ile Store üzerinde commit işlemi yapacağınız zaman karşınıza Vue'nun reaktivitesi sorunu çıkacaktır. Değişim yaptığınız veri ile değişen verileriniz birbirleri ile reaktif bir şekilde çalışacağından iki veri arasında bir bağ kurulmuş olacak ve siz store üzerinde değişiklik yapmadığınız halde değişim yapmış olduğunuz veri üzerinde değişiklik yaptığınızda Store üzerindeki veri de bundan etkilenecektir. Aşağıdaki örnekleri inceleyelim.
state: {
user: {
id: 1
}
},
Yukarıdaki user'a bir mutation uygulayalım.
mutations: {
setUserName (state, userData) {
// userData = {
// id: 2,
// name: Ali
//}
state.user = userData;
}
Yukarıda gördüğünüz gibi "userData"yı direk "user"a mutate ettik. Şimdi "userData" yı bir Vue bileşeni içerisinde "userData.name = Veli" yaparsak, Store üzerindeki "user.name" de değişmiş olacak. Bu yüzden aşağıdaki yöntemler ile bu sorunu aşmanız gerekir.
state: {
user: {
id: 1
}
},
getters: {
getUserId: state => state.user.id,
getUserName: state => state.user.name
},
mutations: {
setUserName (state, name) {
// İlk çözüm:
// user üzerinde değeri önceden belirtin örn: user.name = null ve şöyle görünmeli
// user: {
// id: 2,
// name: null
// }
// Böylelikle "name" daha önceden belirtildiği için Vue içerisindeki değişiklik
// burayı tetiklemeyecek
state.user.name = name
// İkinci çözüm:
// Object assign methodu ile her iki verinin de referansını sıfırlayın
// Object.assign({}, state.user, { name })
state.user = { ...state.user, name }
// Üçüncü çözüm:
// Vue'nun kendi içerisindeki Vue.set() fonksiyonunu kullanın.
// Aynı sonucu verecektir.
Vue.set(state.user, 'name', name)
}
Vue'nun reaktivitesinin Mutations üzerindeki etkisini ve bunun bir sorunken üç farklı yol ile çözümüne değindik. Tekrar hatırlatmakta fayda var bu sorun tam olarak düz Vue kullanırken karşılaşabileceğiniz bir durum. CLI üzerinde böyle bir sorun yaşamayacaksınız. Bir sonraki yazımda Mutatitonsların sabitler ile kullanımına değineceğiz. Teşekkürler.