Solution for a Particular Lazy Load Issue
-
I had a case where the plug-in worked perfectly without Lazy Load, with galleries created the conventional way, with Medium size images linked to full-size files.
However, when I clicked Lazy Load on in the plug-in settings, the containers the images were inside, the “figure” tag containers, were as tall as the original images were natively, and not as tall as the images as rendered.
The columns in my installation were 150px wide. So, if a 300×200 image was to be displayed, the image itself smooshed down to 150px wide and remained proportionate, but the container height stayed as wide as the image started out.
In other words, instead of the container being more or less invisible because it’s matched the smooshed image height of only being 100px tall, it stayed 200px tall like the original image was, which leaves pockets of empty space or background color (depending on your CSS). It still laid out nicely, but of course you just want all images and not pockets of nothing.
Because I am on the most recent version of WordPress, I edited “masonry-init-v3-lazy.js” and changed this:
$(this).closest('.gallery-item').css({ 'width': $(this).attr('width'), 'height': $(this).attr('height') / resizeProportion })
into this:
var realWidth = $(this).attr('width'); var resizeProportion = realWidth / 150; $(this).closest('.gallery-item').css({ 'width': $(this).attr('width'), 'height': $(this).attr('height') / resizeProportion })
All I’ve done is checked out the difference between the starting width of each image and the known column width, distilled that into a factor (2, 1.33333, 1.266667, etc.) and then divided the container height by that to match the image as rendered.
I am not sure why my specific use case borked to begin with; it was the same on two very different sites. If anyone runs across that though, it’s working swell for me now. Hopefully it can help someone.
https://www.ads-software.com/plugins/jquery-masonry-image-gallery/
- The topic ‘Solution for a Particular Lazy Load Issue’ is closed to new replies.