#5062 closed defect (bug) (fixed)
Add native lazy loading on theme archive images
Reported by: | jonoaldersonwp | Owned by: | coffee2code |
---|---|---|---|
Milestone: | Priority: | low | |
Component: | Theme Directory | Keywords: | performance |
Cc: |
Description
Theme archive templates, like https://en-gb.wordpress.org/themes/, load a lot of images - many of which are frequently initially outside the viewport.
We should add a loading="lazy"
attribute to the <img>
tags in these cases to force them to encourage them to only load when they're visible.
Change History (6)
#2
@
4 years ago
- Owner set to coffee2code
- Resolution set to fixed
- Status changed from new to closed
In 9630:
#4
follow-up:
↓ 5
@
4 years ago
At @dufresnesteven's suggestion, I've made a code tweak ([9631]) and then lowered the posts_per_page
value (via the WP admin) to 12. We can adjust as necessary.
#5
in reply to:
↑ 4
;
follow-up:
↓ 6
@
4 years ago
Replying to coffee2code:
At @dufresnesteven's suggestion, I've made a code tweak ([9631]) and then lowered the
posts_per_page
value (via the WP admin) to 12. We can adjust as necessary.
Be careful as to how that impacts API clients (ie. WordPress), I believe clients should be passing a specific number, but I can't quite recall. Test a WordPress instance through a probably-not-cached query (Search or tags) after changing them.
#6
in reply to:
↑ 5
@
4 years ago
Replying to dd32:
Replying to coffee2code:
At @dufresnesteven's suggestion, I've made a code tweak ([9631]) and then lowered the
posts_per_page
value (via the WP admin) to 12. We can adjust as necessary.
Be careful as to how that impacts API clients (ie. WordPress), I believe clients should be passing a specific number, but I can't quite recall. Test a WordPress instance through a probably-not-cached query (Search or tags) after changing them.
Good point. Definitely should be tested but should be low risk.
The only case where it won't fetch more items is if the page is not long enough and the window onscroll
event is not triggered. Otherwise it may show all 12 on screen and on any movement will fetch the next page.
I quickly tried to adding
loading="lazy"
as a progressive enhancement but it didn't work. I'm not super familiar with how it works under the hood, my guess is that our use of JS to inject the images triggers the immediate download.If we are concerned about performance, we can look at reducing the
postsPerPage
. It's currently set to24
, which amounts to about ~500kb
of images on page load. Larger viewports see 9 images at most. So we could set it to12
( 3-6 extra images downloaded on tablet+ viewports).That property is provided to the page in the
_wpThemeSettings
configuration object.