-
Notifications
You must be signed in to change notification settings - Fork 2.2k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Multi-serve fluid images based on width break-points? #144
Comments
URL of the page you have problems with? |
Created a condensed version at http://jsfiddle.net/efdeevee/WETGD/ to show what I'm trying to do. The CSS for img widths is set to 256, 512 and 1024. The script adds/updates a data-display attribute on load/resize, which contains the data taken from the data-large, data-medium and data-small attributes. On load seems to work, but I'm not sure how to have lazyload listen to resize changes in order to serve the best image size. Is it at all possible? Thank you for looking! |
I think it is because jQuery caches the value of $.data() calls. You could try to change lines https://github.com/tuupola/jquery_lazyload/blob/master/jquery.lazyload.js#L105
to
https://github.com/tuupola/jquery_lazyload/blob/master/jquery.lazyload.js#L127
to
To see if that causes the problem in your case. |
It does the trick! Along with your modification suggestions above, I ended up using the following which now includes a device ratio check as well.
I hope it could be of use to someone else. |
Ok thanks! I probably change |
Good news, thanks again. |
Related to #101 |
Update. Although the benefits of serving multiple dimensions might be obvious, I'm finding the above a bit expensive on memory when displaying multiple images on a page. Especially Firefox seems to become less responsive, probably because of the amount of cached alternative sizes. Still searching for a more stable solution to make things lighter somehow. I recall reading an issue here suggesting to unload things when it's moved out of the viewport, perhaps worth exploring... |
Fixed in 1.9.x. |
I'm trying to track image widths and change the contents of data_attribute in order to serve the best possible size.
So far I have the following condensed code which adds a data-display attribute containing the correct data on resize.
The new attribute is added and changes correctly, but unfortunately I can't get lazyload to listen to the new data.
Bit new with jQuery I'm afraid, could this be on the right track at all?
The text was updated successfully, but these errors were encountered: