-
Notifications
You must be signed in to change notification settings - Fork 2.8k
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
Early termination of navigation loading spinner on cross-document navigation #9090
Comments
That's correct. An example:
The main use case is that you have lots of more content that will stream in at the bottom of the HTML document but you've effectively already finished loading or are showing a custom loading state to the user already. This can be because the bottom include data or meta data that isn't visible to the user anyway (e.g. "hydration data") or it can be HTML that gets injected into the page later in slots that already have inline loading states and don't need a global one. Although even better would be to have it work without JavaScript. E.g. some placeholder in the HTML would be enough. E.g.
It could potentially also be an attribute annotation to indicate that when an element "ends" the essence of the document is already done. |
For context, we have gotten some feedback that it feels faster when the same site does a secondary request from the client to the server to fetch more content with script - instead of embedding it into the stream. Objectively it's not "faster" to do the second roundtrip but the indicator stopping earlier makes it feel faster because the main UI is stable faster. |
I've noted this as part of a cluster of related possibilities for exposing more about the initial load, over at WICG/navigation-api#256 (comment). But let's talk more in this issue about exactly what the ask is here. I think the big question is how much does this method do, either by default or as an option. Here are various things it could do:
I think at least (1) and (2) should be coupled. Maybe anything further is unwanted? Not sure. |
@sebmarkbage was mentioning that in some of their server streaming HTML cases, the user agent loading spinner continues long after the important parts of the page have loaded.
If developers had some way of early terminating the loading spinner with JavaScript, that could provide a better user experience. This would not involve modifying actual loading behavior, merely the loading spinner indicator.
Correct me if I misunderstood the request Seb.
The text was updated successfully, but these errors were encountered: