vercel/next.js
View on GitHubScrolling happens when user returns to a page with hash using browser back button
Open
#13653 opened on Jun 2, 2020
good first issue
Description
Bug report
Describe the bug
When user returns to a page which have url with hash (e.g. http://localhost:3000/test#anchor) from another page, unexpected scrolling to the anchor element happen.
It seems componentDidUpdate of Container triggers scrollToHash even when one returns by clicking browser back button.
(https://github.com/vercel/next.js/blob/v9.4.4/packages/next/client/index.js#L135-L137)
To Reproduce
Example repo: https://github.com/monae/nextjs-scrolltohash-bug
git clone git@github.com:monae/nextjs-scrolltohash-bug.gitandnpm run dev.- Click on 'Open the test page without hash'. You are on top of the page.
- Scroll down and click on 'Open another page'.
- Click on browser back button, then you return to the preserved scroll position (Chrome, Safari) or top of the page (Firefox).
- Back to the first page and click on 'Open the test page with hash'. You are on the anchor element.
- Scroll down and click on 'Open another page'.
- Click on browser back button, then you return to the anchor element.
Expected behavior
The results of 4. & 7. should be same (although the behavior of Firefox is not desirable).
Screenshots
System information
- OS: macOS
- Browser (if applies) Chrome, Safari, Firefox
- Version of Next.js: 9.4.4
- Version of Node.js: 14.3.0