-
Notifications
You must be signed in to change notification settings - Fork 27.3k
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
[NEXT-1208] Hot reloading in the app directory causes infinite rerenders #49881
Comments
I've just run into this same issue and boiled it down to as small an issue as I can find For me, all you need is an empty page inside the
Editing anything causes an infinite loop. This happens within any file that is underneath any It seems to be the combination of EDIT: The workaround I've found is to disable any high-level
|
This comment was marked as spam.
This comment was marked as spam.
Same issue here, this bug happens even in production build. |
Im using turborepo and there was a bug in turborepo. Updating turborepo solved the issue for me. |
We're having the same issue with Next 13.4.4. We can't avoid having a high level client component since we need to inject a client side provider on the layout, perks of web3. I tried moving to 13.4.3 as @skworden mentioned it was working then, but still the same issue. Here's my package.json in case it helps: {
"name": "arboretum",
"version": "0.1.0",
"scripts": {
"dev": "next dev",
"format": "prettier \"src/**/*.{css,js,json,jsx,ts,tsx}\"",
"build": "next build",
"format:write": "prettier --write \"src/**/*.{css,js,json,jsx,ts,tsx}\"",
"start": "next start",
"lint": "next lint",
"db:push": "drizzle-kit push:mysql",
"db:check": "drizzle-kit check:mysql"
},
"dependencies": {
"@hookform/resolvers": "^3.1.0",
"@phosphor-icons/react": "^2.0.9",
"@planetscale/database": "^1.7.0",
"@radix-ui/react-accordion": "^1.1.2",
"@radix-ui/react-avatar": "^1.0.2",
"@radix-ui/react-collapsible": "^1.0.2",
"@radix-ui/react-dialog": "^1.0.3",
"@radix-ui/react-dropdown-menu": "^2.0.4",
"@radix-ui/react-label": "^2.0.1",
"@radix-ui/react-popover": "^1.0.5",
"@radix-ui/react-radio-group": "^1.1.3",
"@radix-ui/react-select": "^1.2.1",
"@radix-ui/react-separator": "^1.0.3",
"@radix-ui/react-slot": "^1.0.1",
"@radix-ui/react-switch": "^1.0.3",
"@radix-ui/react-tooltip": "^1.0.6",
"@rainbow-me/rainbowkit": "^1.0.1",
"@t3-oss/env-nextjs": "^0.4.0",
"@tanstack/react-query": "^4.29.12",
"@tanstack/react-table": "8.9.1",
"@types/node": "20.1.4",
"@types/react": "18.2.9",
"@types/react-dom": "18.2.4",
"autoprefixer": "10.4.14",
"class-variance-authority": "^0.6.0",
"clsx": "^1.2.1",
"cmdk": "^0.2.0",
"connectkit": "^1.4",
"drizzle-orm": "^0.26.5",
"eslint": "8.40.0",
"eslint-config-next": "13.4.2",
"iron-session": "^6.3.1",
"lucide-react": "^0.241.0",
"mysql2": "^3.3.3",
"next": "13.4.3",
"postcss": "8.4.23",
"react": "18.2.0",
"react-dom": "18.2.0",
"react-hook-form": "^7.44.2",
"react-hot-toast": "^2.4.1",
"react-icons": "^4.9.0",
"siwe": "^2.1.4",
"tailwind-merge": "^1.12.0",
"tailwindcss": "3.3.2",
"tailwindcss-animate": "^1.0.5",
"tailwindcss-radix": "^2.8.0",
"typescript": "5.1.3",
"viem": "^0.3.39",
"wagmi": "^1.0.9",
"zod": "^3.21.4"
},
"devDependencies": {
"drizzle-kit": "^0.18.1",
"prettier": "^2.8.8",
"prettier-plugin-sort-imports-desc": "^1.0.0",
"webpack": "^5.84.1"
}
} Our layout structure is something like this <html lang="en" className={inter.variable}>
<body className="font-sans h-screen max-h-screen grid grid-rows-[min-content_1fr_min-content]">
<ClientLayout>
<SiteHeader /> // Client component
<div className="h-full overflow-y-auto w-full">{children}</div>
<SiteFooter /> // Client component
<Toaster />
</ClientLayout>
</body>
</html> |
We're aware of this and exploring solutions to better handle this. In the meantime, you should use a server component for data fetching, and forward the result to a client component. This is effectively the same thing as a "data loader" like |
Same issue, and it's even get worse when you add custom hooks into the component. It makes unresponsive the whole page. You can call a async function in Layout as serverClientComponent and pass it to the client component as a parameter. |
@TommySorensen please ensure you are not using an |
@leerob Thx for heads up. I'm running |
@TommySorensen In my initial reproduction I didn't have any async client components either. I had an async server component which was imported inside of a client component that fetched some data. |
@leerob I found the cause of it. I'm using parallel routes where i didn't use the // Fixed by passing null in (shop) folder
export default function TestPage() {
return null;
} I guess this is a bug, since the docs does not say that the page is required at that level. |
@TommySorensen fixed here #52061. |
@leerob Seems like the bug still exsist in v. 13.4.8. I do not have a reproduction you could test on unfortunately. |
@TommySorensen - try the latest canary version - #52061 was released as part of v13.4.9-canary.2. I do still see infinite refreshing in next dev with my dynamic routes inside of parallel routes with that version though, so I may have to create a minimal repro for it. Update: created a minimal repro @ https://github.com/tnoor-co/next-infinite-parallel-refresh and I'll continue to the conversation in PR linked. |
Me too, infinite re-render into parallel routes still exists here |
This comment has been minimized.
This comment has been minimized.
Greetings. It seems that #52362 didn't fix this and the issue is present as of now, and blocks me from using parallel routes. A repro made by @subfallen – https://github.com/subfallen/nested-routes-inf-refresh-repro/blob/main/README.md proves the issue still exists (#52061 (comment)): NextJS Version: |
|
Not reproducible in the latest canary. |
This is still an issue in 14.0.4 |
I see this issue when I have both app router and pages router in my old project. The reload happens 2 3 times with full refresh of the page |
Also had this infinite re-rendering issue with a server-side component being used within a client-side component. LazyLoading with React.Lazy() + Suspense fixed it for me :) |
When I put I'm using next.js 14 |
Hey everyone, this is one of the common mistake with using Client Component and Server Component together. Let's say we have a Server Component If you import
Therefore we have to pass I opened a PR with fix to @UgoRomi's repro, feel free to take a look at the actual migration. |
@marcinincreo @blooser @Hrishi1999 @sehrish30 Hey everyone! Are your problem(s) related to the pattern I introduced above? |
Closing as #49881 (comment) is sufficient for this issue, and is currently expected behavior in React, yet. |
This closed issue has been automatically locked because it had no new activity for 2 weeks. If you are running into a similar issue, please create a new issue with the steps to reproduce. Thank you. |
Verify canary release
Provide environment information
Operating System: Platform: darwin Arch: arm64 Version: Darwin Kernel Version 22.4.0: Mon Mar 6 20:59:28 PST 2023; root:xnu-8796.101.5~3/RELEASE_ARM64_T6000 Binaries: Node: 19.9.0 npm: 9.6.3 Yarn: 1.22.19 pnpm: 8.5.1 Relevant packages: next: 13.4.3-canary.1 eslint-config-next: N/A react: 18.2.0 react-dom: 18.2.0 typescript: 4.9.4
Which area(s) of Next.js are affected? (leave empty if unsure)
App directory (appDir: true), Data fetching (gS(S)P, getInitialProps)
Link to the code that reproduces this issue
https://github.com/UgoRomi/hot-reload-rerender-bug
To Reproduce
pnpm dev
page.tsx
orAsyncServerComponent.tsx
and save the fileswr
Describe the Bug
Whenever you fetch data in a Client Component that has an async Server Component as a child, hot reloading the files will cause infinite rerenders
Expected Behavior
To not have infinite rerenders
Which browser are you using? (if relevant)
No response
How are you deploying your application? (if relevant)
No response
NEXT-1208
The text was updated successfully, but these errors were encountered: