Redux Persist, Redux kullanan React uygulamalarında durum yönetiminin en önemli sorunlarından birini çözer: sayfa yenilendiğinde veya uygulama yeniden açıldığında Redux store’unun sıfırlanmasını engellemek. Bu rehberde Redux Persist’in ne olduğunu, neden kullanıldığını ve ReactJS üzerinden adım adım nasıl uygulandığını açıklıyoruz.
Not: Bu anlatım ReactJS üzerinden yapılacaktır.
İçindekiler
Redux kullandığımız uygulamalarda sayfa değiştiğinde, yenilendiğinde veya uygulama kapatılıp tekrar açıldığında, Redux’taki değişkenlerin tekrar eski haline dönmesi veya sıfırlanması sebebiyle bu değişkenlere ulaşamayız. Bu yüzden sayfa yenilendiğinde tekrar istek atılır ve değişkenler yeniden setlenir. Özellikle servisten gelen sabit objeler veya array’lerde bu can sıkıcı hale gelir — çünkü tekrar servise istek atılıp değişken yeniden setlenmek zorunda kalınır.
Bu problemi somutlaştırmak için bir örneğe bakalım: Login sayfamızı reducer’a yazdığımız loginState adında boolean bir değişkene bağladığımızı düşünelim.
loginState
Bu değişken true olduğunda login sayfası, false ise dashboard sayfası gözükecektir.
true
false
Redux Persist kullanmadığımızda sayfa her yenilendiğinde reducer sıfırlanacak, loginState eski haline dönecek yani true olacak ve login sayfası tekrar gözükecektir. Daha önceden giriş yapmış olmamıza rağmen tekrar login ekranıyla karşılaşırız.
Ancak Redux Persist kullanıldığında böyle bir durum yaşanmayacak; loginState‘i true‘ya setlemediğimiz sürece login sayfası gözükmeyecektir.
Redux Persist, Redux’taki değişkenlerin sayfa yenilendiğinde, değiştiğinde veya uygulama kapatılıp tekrar açıldığında sıfırlanmasını engelleyen; bu değişkenleri localStorage‘da saklayan bir pakettir. Temel çalışma prensibi şudur: uygulama her açıldığında Redux store’u localStorage’dan yeniden yüklenir (rehydrate) ve kullanıcı bıraktığı yerden devam edebilir.
Uygulamada hangi reducer’ların persist edileceğini whitelist ile belirleyebilir, persist edilmesini istemediklerinizi ise blacklist ile dışarıda bırakabilirsiniz. Eğer hiçbir ekleme yapmazsanız reducer’daki tüm değişkenler localStorage’a kaydedilir.
Aşağıdaki paketlerin kurulması gerekmektedir:
TERMINAL
npm i redux npm i react-redux npm i redux-persist npm i reselect
Kuracak olduğumuz Redux ile index.js ve App.js dosyalama yapısı şu şekilde olacak:
index.js
App.js
Adım 1: Action’daki set fonksiyonu için constant bir değer tanımlayalım.
Adım 2: action.js dosyasında set fonksiyonumuzu tanımlayalım.
action.js
Adım 3: Reducer dosyasını oluşturalım ve değişkenimizi tanımlayalım.
Adım 4: selector.js‘ten loginState için bir select fonksiyonu yazalım.
selector.js
Adım 5: index.js dosyamızı oluşturalım. Eğer bir servise istek atılacak ve saga kullanılacaksa aşağıdaki kod satırlarında yorum satırı yapılan satırları aktif hale getirebilirsiniz. Whitelist’e sürekli kaydedilmesini istediğiniz değişkenleri, blacklist’e ise kaydedilmesini istemediklerinizi ekleyin.
Redux Persist’in en önemli özelliklerinden biri, hangi reducer’ların localStorage’a kaydedileceğini kontrol edebilmenizdir. Bu kontrol iki yöntemle sağlanır:
Whitelist: Yalnızca listede belirttiğiniz reducer’lar persist edilir. Diğer tüm reducer’lar her sayfa yenilenmesinde sıfırlanır. Bu yöntem, hangi verilerin kalıcı olacağını kesin olarak kontrol etmek istediğinizde idealdir.
Blacklist: Listede belirttiğiniz reducer’lar persist edilmez; geri kalanların tamamı kaydedilir. Persist edilmesini kesinlikle istemediğiniz hassas veya geçici veriler için kullanılır.
Temiz ve sürdürülebilir React kodu yazımı hakkında daha fazla bilgi için Temiz Kod Yazmak yazımızı, JavaScript’in temel veri yapıları için ise JavaScript Array Methodları yazımızı inceleyebilirsiniz.
Özetlemek gerekirse redux-persist paketi, bir değişkeni tekrar tekrar istek atıp set işlemi yapmak yerine tek bir istekte setleyip siz değiştirmediğiniz sürece aynı kalması sayesinde oldukça kullanışlı bir pakettir. Kullanıcı deneyimini iyileştirirken aynı zamanda gereksiz servis isteklerini azaltarak uygulama performansına da katkı sağlar.
Yukarıdaki kod örneklerinin tamamını görmek için redux-persist resmi GitHub reposunu ziyaret edebilirsiniz. Diğer blog yazılarımıza göz atmak için blog sayfamızı ziyaret edebilirsiniz.
Redux Persist localStorage’a hangi verileri kaydeder?
Varsayılan davranışta Redux Persist, reducer’daki tüm değişkenleri localStorage’a kaydeder. Whitelist kullanarak yalnızca seçtiğiniz reducer’ların kaydedilmesini, blacklist kullanarak bazı reducer’ların kaydedilmemesini sağlayabilirsiniz. Bu sayede hassas ya da geçici verilerinizi persist kapsamının dışında tutabilirsiniz.
Redux Persist Redux Toolkit ile birlikte kullanılabilir mi?
Evet. Redux Toolkit (RTK) ile redux-persist birlikte kullanılabilir; ancak RTK’nın serializability middleware’i persist actions için uyarı verebilir. Bu sorunu çözmek için configureStore yapılandırmasında middleware ayarına serializableCheck: { ignoredActions: [FLUSH, REHYDRATE, PAUSE, PERSIST, PURGE, REGISTER] } eklenmesi gerekir.
configureStore
serializableCheck: { ignoredActions: [FLUSH, REHYDRATE, PAUSE, PERSIST, PURGE, REGISTER] }
Redux Persist ile React Native’de state kalıcılığı nasıl sağlanır?
React Native’de web tarayıcısının localStorage’u bulunmaz. Bu nedenle @react-native-async-storage/async-storage paketini kurup persistConfig yapılandırmasında storage: AsyncStorage olarak belirtmeniz gerekir. Kalan yapılandırma React web uygulamalarıyla özdéştir.
@react-native-async-storage/async-storage
persistConfig
storage: AsyncStorage
Redux Persist kullanırken store sıfırlanması gerekirse ne yapmalıyım?
Kullanıcı çıkış yaptığında ya da store’un tamamen temizlenmesi gerektiğinde persistor.purge() metodunu çağırabilirsiniz. Bu metod localStorage’daki persist edilmiş tüm verileri temizler ve store bir sonraki yüklenmede başlangıç durumuna döner.
persistor.purge()
redux-persist — Resmi GitHub Reposu Redux — Resmi Dokümantasyon Temiz Kod Yazmak — MDP Group JavaScript Array Methodları — MDP Group
Software Developer
Ürün Takip Sistemi Nedir? Kapsamlı Rehber
ÜTS Nedir? ÜTS Bildirimi Ne İşe Yarar?Ürün takip sistemi (ÜTS), ihraç veya ithal edilen tüm tıbbi cihazların ve kozmetik ürünlerinin...
SAP Fiori Client Alternatif: Uygulama Mağazası Kaldırma Sonrası Çözüm
SAP Fiori Client Uygulaması 2022’nin ikinci çeyreğinde Apple ve Google uygulama mağazalarından kaldırılacak. Peki bu gelişme Fiori kullanan...
SAP Build Work Zone Nedir?
Günümüz iş dünyasında işletmeler, iş süreçlerini yönetirken birden fazla uygulama sistemleri ve parçalara ayrılmış bilgilere ulaşmaya...
Fiori Hızlı Aktivasyonu (Fiori Rapid Activation) Nedir?
SAP Fiori, çeşitli cihazlarda SAP kullanıcı arayüzünü sadeleştirmek ve modernize etmek için tasarlanmış bir kullanıcı deneyimi (UX)...
SAP TM’de Uyumsuzluk Yönetimi (Incompatibilities) Nedir?
Giriş SAP Transportation Management (SAP TM), planlama motoru ve taşıma nesneleri üzerinde kapsamlı kontrol sunan modüler bir yapıya sahiptir....
SAP Transportation Management (TM) Nedir?
Bu blog gönderisinde, şirketlerin maliyetleri düşürmesine, müşteri hizmetlerini iyileştirmesine ve tedarik zinciri görünürlüğünü...
SAP FI Üzerinden e-Beyanname Süreçleri Nasıl Yönetilir?
GirişSAP FI üzerinden e-Beyanname yönetimi, Türkiye’de GİB uyumlu vergi beyannamelerinin otomatik hazırlanmasını, doğrulanmasını ve...
SAP Bulut Sistemlerinde Üç Katmanlı Genişletilebilirlik Modeli
SAP, müşterilerinin sistemlerini ihtiyaçlarına göre genişletebilmesi için kapsamlı bir çerçeve sunuyor. Bu model sayesinde şirketler, SAP...
e-Fatura Nasıl İptal Edilir? Adım Adım Güncel Rehber 2026
Yanlış tutar, hatalı alıcı bilgisi ya da iptal edilen siparişler, e-fatura düzenleyen işletmelerin sıkça karşılaştığı...
Mailiniz başarıyla gönderilmiştir en kısa sürede sizinle iletişime geçilecektir.
Mesajınız ulaştırılamadı! Lütfen daha sonra tekrar deneyin.