Swipe back on mobile browser with getInitialProps flickers the previous page
See original GitHub issueBug report
Describe the bug
On mobile browsers (tested with Chrome and Firefox), swiping back or forward on a dynamic page (one that gets data from getInitialProps
) will sometimes “flash” the previous page while the content is loading. Here is a video that shows the problem.
To Reproduce
- Create a next.js app with the following pages:
index.js
import Link from "next/link";
export default function Index() {
return (
<div>
<p><Link href="data"><a>Link</a></Link></p>
</div>
);
}
data.js
const Index = props => {
return (
<div>
<h1>Test mobile back</h1>
<ul>
{props.data.map(name => (
<li key={name}>
<a>{name}</a>
</li>
))}
</ul>
</div>
)
};
function sleep(ms) {
return new Promise((resolve) => {
setTimeout(resolve, ms);
});
}
Index.getInitialProps = async function() {
await sleep(1000)
return {
data: ["one", "two", "three", "four", "five", "six"]
};
};
export default Index;
- Run it, and access it with a mobile browser.
- Click on the link, you are now on a page with “one”, “two”…
- Swipe back
- Now swipe forward. Notice the “flash” of the previous screen.
Now, add "seven"
to the data returned in data.js
, and notice the problem doesn’t happen anymore
Expected behavior
No flash of the previous page when swiping forward or backward on mobile browser. This is what happens now vs this is what should happen
System information
- OS: MacOS
- Browser (if applies): Mobile Safari, chrome and firefox
- Version of Next.js: 9.2.1
Issue Analytics
- State:
- Created 4 years ago
- Reactions:8
- Comments:10
Top Results From Across the Web
Visible Flicker When Using Swipe Navigation in Safari OS X ...
In Safari, however, the swipe to navigate backwards or forwards (where the previous page is revealed as you swipe) flickers momentarily ...
Read more >custom document next js Code Example - Code Grepper
Run the parent `getInitialProps`, it now includes the custom `renderPage` ... How to get the browser to navigate to a URL in JavaScript ......
Read more >Untitled
Currently the screen remembers its position when you navigate away from it, then if you navigate back to that screen, the screen may...
Read more >Get Around on your Pixel Phone - Guidebooks with Google
Go Back. To go back to a previous page or app, swipe from the left or right edge of the screen.
Read more >Contribute to vercel/next.js · GitHub
using-preact example - `next dev` displays a blank page on error when ... Swipe back on mobile browser with getInitialProps flickers the previous...
Read more >Top Related Medium Post
No results found
Top Related StackOverflow Question
No results found
Troubleshoot Live Code
Lightrun enables developers to add logs, metrics and snapshots to live code - no restarts or redeploys required.
Start FreeTop Related Reddit Thread
No results found
Top Related Hackernoon Post
No results found
Top Related Tweet
No results found
Top Related Dev.to Post
No results found
Top Related Hashnode Post
No results found
Top GitHub Comments
@dirkjf personally, the approach I went for was invalidating the snapshot of the page that webkit generates. This line contains the conditions under which the snapshot will be generated when you swipe backwards/forwards to navigate. So I created a hacky hook that I placed in
_app
in order to invalidate the snapshot as much as I could.same issue. it looks like having relation with user’s swiping speed sometimes, but it’s not sure.