Opened 9 years ago
Closed 9 years ago
#31789 closed enhancement (fixed)
Themes: allow a pre filter in `wp_prepare_themes_for_js()`
Reported by: | mattwiebe | Owned by: | SergeyBiryukov |
---|---|---|---|
Milestone: | 4.2 | Priority: | normal |
Severity: | normal | Version: | 4.2 |
Component: | Themes | Keywords: | has-patch commit |
Focuses: | performance | Cc: |
Description
On a site like WordPress.com which has ~450 themes, wp_prepare_themes_for_js()
is very slow. Unfortunately there isn't a pre_
filter that lets us short-circuit the manual labour every time it's called. Fortunately adding one is easy!
This becomes more important in the context of theme browsing in the Customizer, which needs to call this every time a different theme is previewed there.
Attachments (4)
Change History (16)
This ticket was mentioned in Slack in #core-customize by mattwiebe. View the logs.
9 years ago
#4
@
9 years ago
Some other things are being looked at with regards to lazy loading so not going to go for this just yet
Lazy loading will only help speed thing up once wp-admin/customize.php
comes down the pipe. None of the approaches there are making an async call for theme data, nor are any planned (that I've seen). The data is still bootstrapped, it's just that maybe the <img>
tags won't be clogging things up, initially. ( #31793 )
Without this filter, I either need to hack core on wpcom to make theme browsing in the Customizer performant, or just disable the feature entirely. 8-10 second initial load times for wp-admin/customize.php
just won't cut it, especially since each time you preview a theme will reload the Customizer and have a really slow load, again.
#5
@
9 years ago
Just to provide a bit more data, here's a set of ab
results, just for loading wp-admin/customize.php
v 4.1.1 min mean[+/-sd] median max Connect: 284 299 16.2 293 347 Processing: 2876 3259 532.5 3093 5031 Waiting: 1733 2066 530.1 1888 3897 Total: 3170 3557 544.9 3392 5378 v 4.2-beta3-31930 min mean[+/-sd] median max Connect: 281 304 22.9 302 375 Processing: 9381 10776 1617.9 10423 16147 Waiting: 7477 8755 1638.2 8366 14265 Total: 9663 11080 1620.2 10733 16441
My wp.com sandbox isn't crazy powerful, but that's still really rough.
#6
@
9 years ago
31789.2.diff refines the approach a little bit and adjusts the filter docs for core style:
- Docs: summary updated: what is filterable, not why
- Docs: removes the justification, e.g. "allows you to do X because of X", as every use case is different
- Docs: Remove the
@return
(unused in hook docs) - Simplifies the code by just passing an empty array to the filter
- Simplify setting the current theme as the first key (since we know it's an array).
#8
@
9 years ago
- Owner set to SergeyBiryukov
- Resolution set to fixed
- Status changed from new to closed
In 31943:
#9
follow-up:
↓ 10
@
9 years ago
This is one of only two filters that are named pre_wp_*
. (The other is pre_wp_nav_menu
.) Of the 140 or so filters that start with wp_
do not have corresponding pre_
(no pre_wp_
) filters. So while the only precedent is pre_wp_nav_menu
, it feels *really* weird. Anyone against pre_prepare_themes_for_js
? @sergeybiryukov @drewapicture @mattwiebe
#11
@
9 years ago
+1 for pre_prepare_themes_for_js
instead.
Done in 31789.3.diff.
Some other things are being looked at with regards to lazy loading so not going to go for this just yet, but milestoning for 4.2 so we don't lose track.