I am using an Image component to display a profile picture but no matter what I do to the image component it will not reload the image. I have to use the same url for the profile pictures so I tried to give the Image a unique key prop to try and get it to reload the image but it still just uses the image from cache. I have changed the image on the server countless times but the Image component only shows the original image it got for the url.
It would be great if there was a prop to pass into Image that forces it to refresh the image every time it is rendered.
In a perfect world it would display the image from cache while fetching the new image, compare the two then decide if the image has changed.
@RyanMitchellWilson What I do as a workaround is add a meaningless query parameter to the url. Now whenever I want the image to reload, I just change that param and that invalidates the cache.
So it turns out I was actually hitting the wrong dev environment for the picture so it just looked as though it wasn't changing when it actually was.
Well it seems I was actually right the first time so I'm going to reopen this issue. I even gave the image a key of Math.random() and it still keeps loading from cache when the image on the server has changed multiple times
Using @ramilushev suggestion worked but it feels hacky and probably shouldn't be needed.
@RyanMitchellWilson have you found a better solution to this ever since then? I do feel that this is an issue that the developers in FB have to look into. its been re-raised and no good solution has been given till now
Same issue here (only this time with FB account images, LOL).
On iOS the image seems to refresh okey-ish after the image view is unmounted, and it also has a cache
props for that.
On android the image is cached for ever unless do something like @ramilushev suggested, although it is only a workaround and not without side effects (e.g. no cache to use after path change, producing too many junk copies in the cache for the same image).
The issue probably boils down to the Fresco library (the Image component uses internally), which currently doesn't seem to have a good knowledge about when to invalidate its cache, and there is no current way of forcing it to invalidate either (or if there is one please let us know).
ios I can set
but android stil bad. please let me know if it be solve.
This issue has been automatically marked as stale because it has not had recent activity. It will be closed if no further activity occurs. Maybe the issue has been fixed in a recent release, or perhaps it is not affecting a lot of people. If you think this issue should definitely remain open, please let us know why. Thank you for your contributions.
This is still a problem
@RyanMitchellWilson
Did you solve the problem?
@dbyilmaz Not exactly I'm still using the work around stated above adding a Math.random() to the query string in a way that doesn't affect the url. This causes the url to be different every time so it will actually fetch the image instead of just grabbing it from the cache.
@RyanMitchellWilson I am using your workaround. I think it is not good. I guess facebook don't think to solve this problem.
@RyanMitchellWilson @dbyilmaz
you can fix this problem by adding new Date() value in key.
like
<Image
key={new Date()}
style={styles.drawerAccountImg}
source={uri: this.state.photoURL}
/>
However, I've not tested in android yet.
Hi
This worked for me on Android emulator:
Hope it hepls
Malina
add a query string after url, works for both platform
source={uri: this.state.photoURL + '?' + new Date()}
/>
Thankz bro...
Adding a query param to the source works. But it's all too hacky.
i'm still cant believe its really works
add a 'time=' param along with image URL, works as well.
Still an issue - cache: 'reload' doesn't work on Android.
Only hacky solutions work but they put a lot of junk images in the cache which is bad...
Still an issue, wish to resolve : )
+1
CACHE prop worked for me.
@I-O-O-I
As mentioned in the thread, that is for IOS only, it does not work for Android.
+1
<Image style={{flex:3,width:'100%'}} source={{uri: image.thumbnailUrl+'?'+new Date().getDate()}} key={
image${i}}/>
This worked for me, currently react native does not have support for android, so we need some kind of hack
hi,
i am using this property for android:-
<Image
source={uri: this.state.uri + '?' + new Date()}
/>
For iOS:-
<Image source={{uri: this.state.uri, CACHE: 'reload'}} />
But any changes doing in that particular screen then image is disappearing like below mentioned gif file :-
Please give any suggestion for this issue.
same issue @harikanammi
I haven't tried this, but in Vue the same happened to me. It didn't work with Date() but it worked with Math.random(). It would be something like this:
<Image source= { uri: this.state.uri + '?rnd=' + Math.random() } />
hi @agamadev, thank you for your reply.
<Image source= { uri: this.state.uri + '?rnd=' + Math.random() } />
this is not working for me.
Image disappearing issue is not fixed.
Hey all. Thanks for reporting this and posting workarounds. It'd be great if someone could send a PR to support some (if not all) the same options as iOS currently does.
If it helps in creating a PR; the native Image view code can be found in the following places;
Internally this uses Fresco's ImagePipeline, which has various caching controls as seen here in the source.
So we want to implement cache property for source on Android with the same implementation as iOS? For reference: https://facebook.github.io/react-native/docs/images#cache-control-ios-only
add a query string after url, works for both platform
style={styles.drawerAccountImg}
source={uri: this.state.photoURL + '?' + new Date()}
/>
Thanks it Working.. :)
Can someone tells React Native 0.59 is stable to upgrade. Currently using 0.57
Yes, this is still a big issue in RN for Android I think..
It means that we just can't ever update the cache of an image when it's downloaded for the first time, unless flushing the whole app's cache.
Workaround work too with local images like /storage/.../asdasd.jpg
Is there anybody who could send a PR like @Salakar was proposing?
what a problem bro 馃拹
I am planing to ask my backend developer to send date of image created along with image uri.
is this still an ongoing issue? been couple of years now
Yeah I think so
I had to do a forcedUpdate and add key
componentDidMount() {
setTimeout(() => {
this.forceUpdate()
}, 2000)
}
Simply adding key={new Date()}
seemed to do the trick for me, even though I see it doesn't seem to key prop available.
Nothing else worked for me, but this fixed it in iOS and Android
I fixed this issue by adding random string.
This is similar to adding date but it wasn't working for me because i may need to encode url for spacing.
<Image
style={styles.image}
source={uri: `${this.state.photoURL}&random=${Math.random().toString(36).substring(7)}`}
/>
OR
If you don't have existing parameters in that image url.
<Image
style={styles.image}
source={uri: `${this.state.photoURL}?random=${Math.random().toString(36).substring(7)}`}
/>
@malinamircu It works for me when appending date time in photo URL, but it will flicker the image.
would be nice if there was a way to flush the image cache for scenarios like this
@mechazod to fix the flicker thing I'm setting
this.state = {now: Date.now()}
in my constructor and using that as the image URL parameter so that it doesn't re-download the image every time the component re-renders
@formaldehydeson Yes, that will be a great idea to avoid the flicker effect.
You also can set new Date().getDay()
instead of Date.now()
, this way it's only refreshed once a day (e.g. if Image is not such important to refresh [or use hours, minutes....).
This way, the refresh isn't that often (which will result in better App-Performance and lower Network-Traffic)
At least, all those Solutions are really ugly and bad for the App-Performance.
In my case, it seems to happen only at some Android-Devices (not at IOS at all). I'm not yet figured out, if it's the Android-Version or special Devices (maybe Manufacturer Changes at the OS).
But I would heavily appreciate if this bug will be analysed and solved soon.
I'm having this issue with a local image. The image is being changed but kept at the same absolute path. The Image component is not re-rendering. I tried CACHE: 'reload', but it doesn't help.
Since my issue here was with user uploaded profile picture images, I ended up adding a timestamp in their profile with the last time they updated their profile picture and I'm appending that to the image url instead of using a date value set in the component constructor. Still pretty annoying that I need to result to that but it gives the best user experience with the least amount of unnecessary re-loads.
add a 'time=' param along with image URL, works as well.
Thanks a lot! 馃憤
Hi , adding some extra params in the image uri worked for me.
Though it is not a proper solution for this issue.
```
> const ImageUrl = `${gameBgImg}?time=${new Date()}`;
> <Image
> source={{ uri: ImageUrl, cache: 'reload' }}
> key={new Date().getTime()}
> / >
```
Experienced same issue. Used randomized parameter to solve it.
Something like:
Very bad solution, hoping for a fix on this for sure!
still is problem
add a 'time=' param along with image URL, works as well.
Hi, Thanks.
This is working for me on Android, but it's taking time to load the image
This is still problem for me - the dummy params workaround isn't acceptable, as my users have super low spec devices, are very data-limited and need to load hundreds of images each render but on the odd occasion that an image changes, it must update.
Saving a timestamp in the URI is also an unusable hack because the images are managed, updated and accessed by a main rails app using a gem. The gem stores and retrieves filenames with a specific syntax.
Is there no way to access the cache, even if it means diving into some native code? The ability to flush an image of a specific reference from the cache seems like a trivial function.
+1
Most helpful comment
add a query string after url, works for both platform
style={styles.drawerAccountImg}
source={uri: this.state.photoURL + '?' + new Date()}
/>