Closed kireerik closed 6 years ago
Thanks, I clearly need more information:
I can confirm that there seems to be something wrong with either detecting when the image is in the "lazyload viewport" or when it is fully loaded. Sometimes my images don't show up on the page even when they are in cache and should be there quickly. Although I cannot yet provide more info other than that this happens for me on Chrome 53.0.2785.143 m and that we're using responsive images with the picture element. I'll try to reproduce this somehow and give more info...
Why can't you distinguish between the situations "wrong viewport detection" and "wrong loaded detection".
At the end I really need a testcase (you don't even need to reduce this a full page/app is enough for me to figure it out).
Because it happens infrequently and when I open the dev tools to see what exactly is going on, it usually also causes the images to show up.
We use the lib on https://energy.ch and it's also where we got the problems sometimes.
So we have a kind of a schrödingers bug. I tried your page and couldn't reproduce it. I will keep on trying.
But I can already give you something to check for yourself. Chrome sometimes seems to handle "pictured" img
elements without initial src
and srcset
attributes quite strange (i.e. all those conditions have to present).
Can you try to add src=""
and check yourself wether this helps.
Just rechecked an empty alt=""
doesn't help. Try to add the src=""
.
Hi @aFarkas,
Thank you for your questions!
src="image/placeholder.png"
. You can experience the reported issue in the slider, which is using Swiper. Elevatezoom is also used on those images in the slider.The reported issue happens when I select a color variant other than the initially selected one. Than I hover the mouse on a thumbnail image, which is on a newly added slide. Than I hover on the image above the thumbnail and the issue occurs.
Thank you for checking the issue in advance!
@kireerik
Your issue is not really comparable with the issue of @marcelgwerder. In case of @marcelgwerder I assume a browser bug, that hopefully can be worked around by using a valid src
or srcset
attribute.
You bug seems more like a JS conflict. I assume the following line(s) produce this:
activeSlide.data('original-content',activeSlide.html()).html(newSlide.html())
/*....*/
previousSlide.html(activeSlideContent).data('original-content', activeSlideContent)
activeSlide.html(activeSlide.data('original-content')).css('background-color', '')
The problem is that you constantly destroy the DOM elements. You can workaround this by either working with the real nodes:
activeSlide.data('original-content',activeSlide.children().detach()).html(newSlide.children())
/* ...
Don't forget the other two lines.
*/
Or by re-adding the lazyload class:
activeSlide.data('original-content',activeSlide.html()).html(newSlide.html()).find('.lazyloading').addClass('lazyload');
/* ...
Don't forget the other two lines.
*/
Hi @aFarkas,
Thank you for your detailed reply! I really appreciate your work!
I re-added the lazyload class, so now my implementation works perfectly.
I only needed to re-add the class at one point, when you hover the mouse over the big image from the thumbnail.
I think now we can close this issue, because it is not closely related to lazysizes, or is it?
@aFarkas (please read the update first or don't read anything and not waste your time, since I understood the issue)
I'm also experiencing this. I have no user-interaction with the images, and they are in the format of <picture>..source.. img.. </picture>
. they are rendered from a javascript template file and injected into the page, after a REST call is made to get the URLs needed for that page.
I am seeing this when my website is being prerendered and the class of the img is changed to preloading
and not to preloaded
. very annoying. and I do give enough time (tried a very long timeout) for the page to "settle down" before telling the prerender the page is ready.
I am also using (picturefill)[https://github.com/scottjehl/picturefill] if that's any helpful information
Ok, I think I understand the situation, the class cannot ever be changed to preloaded
because that requires the image to actually load, and that is happening way after the preloader server was fired and prerendered the page, at that point javascript does not exist anymore. I would have to find a way to manually change all the classes.
Seems like, for some reason, lazysizes does not work at all on some pages, even though I guaranteed the integrity of the markup (printed the innerHTML of a picture
element on the screen and even called window.lazySizes.init();
but it just doesn't do anything. (still using data-srcset
without modification. with class lazyload
present on the img
itself. odd!
Any possible workarounds for this issue? I have the same issue with a new project but it is only in IE. The first images in the viewport gets loaded and the rest of them stuck at class 'lazy-loading'. Any update one this issue? pls help. Thanks
Hi, I'm experiencing the same issue after update from v.2.0.0 to 4.0.0. recently (on all major browsers including Chrome). Not on every place, but some images have still "lazyloading" state class. Only that class with its own style cause the zero opacity and makes image invisible. This is only happening when I'm directly on the same screen while lazyload is applied. When I'm scrolling from the top after refresh, everything works well. One more note is, that those images are loaded dynamically with Angular. Any ideas how to fix it (I would rather some systematic solution rather than some hotfix mentioned above - just find "lazyloading" class and replace it with lazyload? Cheers.
@VonSandberg Can you give me a URL to check this bug?
@VonSandberg
It would be extremely important for me to get access to a testcase or the real site or something to see this regression bug. Please help!!!
@aFarkas I know. Unfortunately, I'm not able to easily demonstrate it (internal project, quite huge).
PROBLEM: Angular process with lazyloading at the same time. Just guess. FIX: We ended up with the simple window.ready function calling init().
@VonSandberg To bad this solution isn't working for me. With the state changing i'm stil getting stuck on the lazyloading even after i call the lazySizes.init() in window.ready.
@wplerp Maybe you forgot to disable the auto init feature?
<script>
window.lazySizesConfig = window.lazySizesConfig || {};
window.lazySizesConfig.init = false;
</script>
<script>
onMyCallback(lazySizes.init);
</script>
@aFarkas Yes! that fixed it. Thank you for your fast response!
fwiw, had a similar issue with Vue, had to delay lazySizes.init until after Vue had mounted our SSR dom elements
@jakedowns I can confirm getting issues with images not leaving lazyloading
with Vue.
(My use case is lazysizes + picturefill + bgset-plugin, but getting the same issue. If I disable Vue, everything works as it should)
I get this same issue of lazyload elements stuck with class "lazyloading" but can see that the image has loaded in dev tools (network). If I clear my browser (Chrome) cache and load up the page, most times the thumbnails have this issue... eg.: http://edwinacorlette.com/artists/clara-adolphs Tried the manual init tricks listed above and still have this issue.
I was using HTML commenting to hide some HTML from being indexed - content that I write into the page on load so I think the rewriting of html (using .html(content) inside document.ready) was causing issues since lazyloading was initialising from the head element - but not entirely sure this was the issue. I did fix it though by doing this at the end of my jquery document.ready script: $('.lazyloading').addClass('lazyload').removeClass('lazyloading'); I did this to try and get any elements stuck in lazyloading to retrigger their loading etc. This seems to have fixed the issue. I thought about delaying the init of lazysizes until the end of document.ready but like the idea of images starting to load ASAP.
@moldedjelly
This is obvious the reason for your issue. At this point the lazyload
class is removed, but the DOM references to the loading elements is destroyed.
The best thing todo is to rewrite you HTML by keeping the lazyload elements. i.e.: Do not use innerHTML and similar method but use dom mutation methods like apendChild, setAttribute etc..
I am still getting this issue on version 4.0.1 on IE11
On this url - https://www.hillarys.co.uk/blinds-range/roller-blinds/
There is a component further down to "A Roller blind for all reasons" I am getting the lazyloading class. This is slowly becoming a sitewide issue. Am I implementing it incorrectly?
Thanks
Matt
Same issue here on IE11. I feel like this has only appeared in the last couple of days, i swear it used to work.
@code-mattclaffey
Use data-srcset
on the img
element instead of data-src
or use a last source
element without a media
attribute condition.
@aFarkas why would adding data-srcset on the img tag work? I have added it in and it did seem to work but in the documentation it states that the image element should have data-src
applied to it? Is data-srcset the attribute to use for picture elements that have different sources?
@code-mattclaffey This is a very specific issue that has to do with how loading in general works and only applies to the following situation:
picture
and you are using a picture
elementsrcset
/data-srcset
on your img
elementsource
has a media
or a type
attributeThe problem is if I add the src
element to img
it downloads this immediately even if this src
is overwritten by the polyfill. This is why I don't change the src
in those browsers.
With my newest change I will automatically mirror the data-src
to the srcset
element in those cases.
Hi,
Even we are also facing the same issue.
Though we scrolled down to the page, src
attibute is not set and network requests were not triggered for images
TIA
@0xc0d3r Pretty sure it is not a lazysizes issue. But you always need to provide a testcase or at least a link to the site, otherwise I can't reproduce the problem.
@0xc0d3r
lazySizes is not included on this page.
@aFarkas Thanks for the prompt response. <3
I'm removing the comment which has the link.
I still encounter this issue with lazysizes and vue on re-used router views (including :key='id'
did not help, but it's a good practice anyway). The issue seems to arise when Vue re-uses same img
tag with the same :key
. Lazysizes does not remove .lazyloading
and in Network tab those images are marked as "Stalled". This affects only a bunch of images that have been preloaded by LS earlier, i.e. images well below the fold are still lazyloaded fine.
I'm not sure who's the culprit here: vue, lazysizes or Chrome, but nor plugins neither any LS configuration options helped to alleviate the issue.
So I ended up building a primitive cache within Vuex that tracks already displayed images (under assumption that they ended up in browser's cache) and once an image is in the cache, it won't be lazyloaded anymore:
mounted() {
const tempCache = new Set([...state.thumbsCache])
response.data.pix.forEach(pic => tempCache.add(pic.id))
state.thumbsCache = Object.freeze(tempCache)
}
In your template something like:
:src="thumbsCache.has(id) ? thumbURL(id): null" :data-src="//opposite logic"
hi @aFarkas, i'm having this issue on https://dekora-angular.firebaseapp.com/home (mobile view). sometimes the image of the first item of the slides doesn't get to load (and sometimes the second). it happens about 1/10 times when i first load the page. I'm using angular 8. Greetings!
@aFarkas I'm just wondering why this issue was closed? This issue is still occurring in IE 11 (as shown in the attached screenshot below. Is there any solution to prevent the lazyloading class from getting stuck?
@aFarkas ,
My videos are getting stucked with 'lazyloading', instead of loazyloaded.
And when I inspect and change lazyloading class to lazyload, it gets to lazyloaded.
kindly let me know the fix for it.
Same problem here with Google Chrome, my first ten elements is lazyloading and not set the class to lazyloaded
Same problem here with bgset plugin and slow response time from images CDN (~2 seconds).
This solved my problem, I just added the init
in the $(document).ready
callback
@wplerp Maybe you forgot to disable the auto init feature?
<script> window.lazySizesConfig = window.lazySizesConfig || {}; window.lazySizesConfig.init = false; </script> <script> onMyCallback(lazySizes.init); </script>
@wplerp Maybe you forgot to disable the auto init feature?
<script> window.lazySizesConfig = window.lazySizesConfig || {}; window.lazySizesConfig.init = false; </script> <script> onMyCallback(lazySizes.init); </script>
@aFarkas I don't know if it's due to the fact that I'm importing the library with webpack, but I don't have an available
lazySizesConfig
variable if I doimport 'lazysizes'; // window.lazySizesConfig will be undefined at the start and then an empty object window.lazySizesConfig = window.lazySizesConfig || {};
In order to extract the config I need to do this instead:
const lazySizesConfig = lazySizes.cfg;
Apart from the that, your solution fixed my issue:
const lazySizesConfig = lazySizes.cfg; lazySizesConfig.init = false; window.addEventListener('load', lazySizes.init);
Some images with
lazyload
class in some cases get sucked in thelaziloading
state with thelaziloading
class, and they never get thelazyloaded
class. However the images are loaded by the browser, but they are not displayed.