Angular's ng-src keeps previous model until it preloads image internally. I am using different image for the banner on each page, when I switch routes, i change main view, leaving header view as it is, just changing bannerUrl model when I have it.
This is resulting in seeing previous banner image while new one is loading.
I was surprised that there's no directive for it yet, but I wanted to make a discussion before trying to build one.
What I want to do I think is have banner model on custom attribute. like:
<img preload-src="{{bannerUrl}}" ng-src="{{preloadedUrl}}">
Then $scope.watch for bannerUrl change, and as soon as it changes, replace ng-src with loader spinner first, and then create temproary img dom element, preload image from preload-src and then assing it to preloadUrl.
Need to think how to handle multiple images too for galleries for example.
Does anyone have any input on it? or maybe someone can point me to existing code?
I've seen existing code on github that uses background-image - but that doesn't work for me as I need dynamic height/width as my app is responsive, and I cannot do it with background-image.
Thank you
visibility: hidden
until the final image is loaded when you change it tovisibility: visible
and thus you only see the final image. – Confidingvisibility:hidden
, then use javascript to see when all images in array are loaded, and set all images tovisibility:visible
then? – Amperehour