-
Notifications
You must be signed in to change notification settings - Fork 2.7k
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
Adjust Scroll Restoration Behavior for Reloads #10597
Comments
I discussed this with @Udassi-Pawan in a chromium code review here; Also It seems Safari already takes this behavior for usual reload and the same URL navigation as reported here; https://g-issues.chromium.org/issues/330207607#comment11 @annevk Do you know the current contact for the Firefox in this area? cc: @jeremyroman for chromium side help from the spec POV. |
There is a separate but related question of whether scroll restoration should be done when users focus the address bar and hit Enter (essentially an explicit navigation to the same URL as the current page). Chrome currently treats this the same as pressing the Reload button, doing scroll restoration in both cases. But prior to 2016 they were handled differently (restoration only on Reload). I would support restoring the pre-2016 behavior, either by enshrining it in the spec, or by resolving here that the behavior of pressing Enter in the address bar is up to the user agent. |
CERTAINLY when focusing the address bar and hitting Enter, scroll restoration MUST be omitted, regardless of what you decide to do on reload. While an argument could be made that, on reload, scroll restoration might actually be desired/expected, it is certainly not the case when hitting Enter from the address bar. The latter is a very explicit request by the user to load the url that is in the address bar, and if that includes a fragment, that includes a specific scrolling position. Also consider the following use case: If you don't make a distinction between (A) focusing the address bar and hitting Enter and (B) pasting or typing a URL into the address bar, resulting in an URL identical to the one that was already there, and then hitting Enter, then (A) and (B) have to be treated equally, and because it would be absolutely inconceivable to treat (B) as a reload, and especially to restore scroll in case (B), then it cannot be restored in case (A) either. And I don't think that making a distinction between (A) and (B) would make sense, it would lead to all kinds of inconsistencies.
If something is to be left to the user agent, I think it should be the other way around. Whether or not to restore scrolling on reload is what could be subject to personal preference and it might make sense to leave it to the user agent (which in turn might want to have a setting for that). On the other hand, restoring scroll when hitting enter from the address bar is absolutely insane, so it makes more sense to prohibit that in the standard. |
I agreed that moving to the top or fragment position rather than scroll restoration is a better behavior for the address bar operation. On the other hand, it's difficult to have an undefined reload-like navigation only for this case. Today, many modern APIs depend on the navigation type. So, such ambiguous navigation causes chained ambiguity on several specs. That's one of the reasons we needed to change the address bar operation to be aligned with the existing reload. Also the scroll position is combined with the mobile screen's zoom scale, and "persisted user state" may need to follow the change. I didn't remember what is classified into the "persisted user state" clearly, but maybe form inputs or/and the zoom scale? For these reasons, I'm supportive to drop the restoration behavior on reloads in general, that includes the address bar operation case. Another possible choice might be doing a normal navigation rather than reload on the address bar operation. That allows us to keep the current behavior for the reload, and can revert the scroll restoration on the address bar operation. For this case, we may not need the spec change as this may be an implementation specific UX choice. Let me paste some relevant spec links that I did also in the code review for the discussion. https://html.spec.whatwg.org/multipage/browsing-the-web.html#persisted-user-state-restoration https://html.spec.whatwg.org/multipage/browsing-the-web.html#reloading-and-traversing https://html.spec.whatwg.org/multipage/browsing-the-web.html#updating-the-document |
The address bar operation is clearly a normal navigation and not a reload. Again, consider the action of pasting a new url into the address bar and then hitting Enter. To compare that to the previous url and then do a reload or a normal navigation depending on whether the two urls are equal or not, is just ridiculous (and it's what Chrome currently does). When the address bar is focused and the user hits Enter, that means "navigate to this URL". Whether or not that url matches the currently loaded url is irrelevant. And what happened before (i.e., did the user type or paste or edit the url or did they just give focus to it and hit enter?) also has to be irrelevant. |
Would this apply to reload from the user interface and history.go(0) ? Scroll restoration is an ancient feature, so I wonder if changing history.go(0) behavior might break some sites. For location bar browsers have different behaviors. In Firefox if there is a fragment included, it is a same document navigation (to that fragment), if not, it is a new load. Not reloading in fragment navigation case is very handy. Browser UI behavior is of course up to the UA, but if we want the spec to change, it would affect history.go(0). |
Shouldn't it be the case, that hitting Enter from a focused address bar containing the url X, should always have the exact same effect as clicking a link that links to url X? |
I'm happy to defer to @skobes-chromium on this. |
I agree with the general principle that browser UI is up to the user agent. I don't see a compelling reason to change the behavior of The idea that address-bar Enter should simply scroll to the fragment in the existing page (same-document navigation) is interesting. I did not realize Firefox did this. It's different from pre-2016 Chrome, which I think was more like a normal document-replacing page load that didn't trigger "reload"-associated behaviors (scroll restoration, invalidating disk cache?) |
@skobes-chromium In the 2016's change, I modified the addres-bar Enter behavior to be consistent with mobiles' pull-to-refresh behavior, and the purpose was to reduce the number of unnecessary conditional requests from Chrome. Users can trigger the pull-to-refresh action only at the beginning of the page. So this would not have been a matter on mobiles. By the way, the article above also said that the reloads on the addres-bar Enter were special for Chrome. So changing it to a normal navigation would be a possible choice? I think people rarely need reload on desktop today, or there are several options to trigger reloads quickly for advanced users, e.g.. Ctrl+R, F5. |
We should also consider the behavior on "hard reload", typically triggered by Ctrl-Reload (or Cmd-Reload, or Ctrl-Shift-R, or probably some combination of ctrl or shift with F5). This "reloads your current page without using cached content". I'm not confident that everyone calls this "hard reload", but will use that term here for now. If others have a better term for it, please advise. In my opinion, a hard reload would ignore the current scroll position (since the current scroll position can be considered "cached content"). This would suggest that a "regular" reload could continue to respect scroll position. Agree with others that URL-navigation should ignore the scroll position. |
Summarising the conversation that we have had so far: There is consensus on omitting scroll restoration from same-URL navigation in the address bar. To achieve this, we have two options: i) Omit scroll restoration from both reload and address bar navigation, making them consistent by not restoring the scroll position in either case. ii) Treat same-URL navigation in the address bar as a normal navigation (without scroll restoration), while preserving scroll restoration for reloads. Any views? |
As a first step, I propose we change same-URL navigation in the address bar to be a normal navigation in Chrome. When the URL has a hash fragment, this would scroll to the fragment in the existing page, without loading it from the network. If I'm reading correctly, this addresses @toyoshim 's original concern about introducing a new navigation type, since we are instead adopting an existing navigation type. Also it aligns us with Firefox, and with @php4fan 's expectation that address bar navigation to url X has the same effect as clicking a link to url X. I have more hesitation about changing the behavior of F5 / Reload button (either regular or "hard" variants). The intent expressed by that UI is less about navigating and more about refreshing the page content. And there is some value in giving users choice by supporting both behaviors. |
Yeah, this seems like the option with minimal overhead and trade-offs. It also aligns well with existing browser behaviors. |
yeah, @skobes-chromium 's proposal sgtm |
I'm in support of @skobes-chromium's proposal as well, and I'm reviewing the change for it at https://chromium-review.googlesource.com/c/chromium/src/+/5896034. Two questions:
Thanks! |
Q2: Yes, if we are to align with the behavior of clicking an If there is a fragment, including an empty fragment (#), then we should just scroll to the fragment. Here is a test page I made to check how links currently behave: https://output.jsbin.com/motaxeg/quiet |
For same url navigation from address bar, Safari seems to behave differently from Firefox. Safari seems to behave like "navigation to a new document": loads from network whether the url has fragment or not. From end user's point of view, it is the same as pre-2016 Chrome behavior. Firefox seems to behave like clicking a link: scrolls to the fragment if the url has a fragment and loads from network when the url does not have fragment. This is the same behavior as if the current page were at the url without the fragment. One thing could be a source of complaint: if the page is already scrolled to the fragment, press Enter on address bar, nothing happens. For @tyoshino's concern, neither behavior seems to require introducing a new type of navigation. It is a choice of navigation to different or same document when url has fragment. I have changes for both approaches in https://chromium-review.googlesource.com/c/chromium/src/+/5896034/17 and https://chromium-review.googlesource.com/c/chromium/src/+/5896034/18. So, the question is: which behavior is more desirable or feels more natural to the user? Would appreciate your opinions. @skobes-chromium, what do you think? For @csreis's question of whether same URL navigation should replace current history entry, I was wondering about the same. Don't know whether current entry is replaced or reused internally, external behavior of Chrome, Firefox, and Safari is that no new entry is added to the history. And the spec seems to in favor of replace. Though not exactly about this scenario, in step 11 of https://html.spec.whatwg.org/multipage/browsing-the-web.html#beginning-navigation:
And in "Note" about history handling behavior https://html.spec.whatwg.org/multipage/browsing-the-web.html#navigation-supporting-concepts:
|
For @csreis's first question about same url navigation from bookmark, it looks like Chrome and Firefox behave the same while Safari behaves differently. Safari loads from network whether the url has fragment or not. Chrome and Firefox loads from network if the url doesn't have fragment, and scroll to the fragment if url has fragment. The 2 scenarios feel similar to me: user uses browser UI to explicitly navigate to a url which happens to be the same as current url. It would be better for the behavior to be the same. |
It seems that we are all supportive of changing Chrome's behavior to not restore scroll position when user enter the same url from address bar. What is not clear to me are the following:
@skobes-chromium, @csreis & @toyoshim, could you clarify your view on the above? |
As-if-click is what I had mind when I wrote #10597 (comment). I have no strong preference re. bookmarks but would lean toward consistency. |
I'm also in support of "as-if-click," which is consistent with Firefox. That means scrolling to the fragment if there is one, rather than loading from the network.
Thanks for pointing this out (and that appearing to do nothing was the actual concern for bookmarks in https://crbug.com/40682643). It does seem consistent with the "as-if-click" approach, and hopefully the greater consistency overall will help both the enter-in-address-bar case and the bookmark case. The user can always use Reload if they want to load the page from network again. I would also support treating bookmarks the same way as enter-in-address-bar, so that they scroll to the requested fragment (and stay there if already scrolled to it). |
Thanks for confirming. Will change Chrome's behavior to "as-if-click". |
When user tries to navigate to the same url from address bar, we currently treat it as a reload where user scroll position is restore. However, user does not expect scroll to be restored. Both Firefox and Safari don't restore the scroll position in this scenario. This change updates the logic to treat same url navigation from address bar as if it is a navigation by clicking on a link to the url. This means that URLs without fragments will load again and scroll to the top while URLs with fragments will scroll to the fragment (staying within the same loaded document if possible). Removed the omnibox code that treat it as reload, and to avoid adding a new navigation entry, updated code in NavigationRequest::ShouldReplaceCurrentEntryForSameUrlNavigation to return true for same document navigation from address bar. Existing logic will replace the current history entry for urls without fragment and reuse current history entry when for urls with fragment. This behaves the same as renderer initiated navigations. With this change, we also fixed part of crbug.com/40755155 and now not adding a new history entry when navigating to the same URL from address bar after a failed navigation. Updated tests to reflect the new behavior and added new test to ensure that user scroll is not restore when navigating to same url from address bar. More discussion at whatwg/html#10597. Bug: 40660533,330207607,40755155 Change-Id: Ic76e74a4c41b407c9ff537b2c3e16df7e4c931c1 Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/5896034 Reviewed-by: Tomasz Wiszkowski <[email protected]> Reviewed-by: Charlie Reis <[email protected]> Commit-Queue: Liang Zhao <[email protected]> Reviewed-by: Moe Ahmadi <[email protected]> Cr-Commit-Position: refs/heads/main@{#1382057}
What is the issue with the HTML Standard?
Currently, the page is typically scrolled to the last saved position during reloads, forward, back, and current page navigations.
While scroll restoration is beneficial for forward and back navigations—where users generally expect to return to where they were—it can lead to inconsistencies in the case of reloads. This is because the content of the page might have changed since the last load, making the previously saved scroll position irrelevant or even misleading
Also hitting the refresh button might be implying that user may want to view the page anew. Preserving the scroll position might counteract this intent by taking them to a part of the page they didn't intend to revisit immediately.
So would it not be best to omit scroll restoration in the case of reloads, while we can keep it intact for other history navigations.
The text was updated successfully, but these errors were encountered: