Support dynamic routes (with dynamic params) in static export mode #55393
Replies: 34 comments 76 replies
-
Our project is private (don't care about SEO) and already has a back-end server, so there's no point in having server-side rendering and in turn, no need to use a node server. But we handle a lot of dynamic data so I'm highly interested in this |
Beta Was this translation helpful? Give feedback.
-
See issue 54393 |
Beta Was this translation helpful? Give feedback.
-
I think this is already planned because App Router is supposed to have the same capabilities as the Pages Router (or at least propose alternate patterns), just not the biggest priority |
Beta Was this translation helpful? Give feedback.
-
THis one is very important to me as I use nextjs with Capacitor to generate iOS and Android apps. In those cases I export dynamic route pages that need to do remote requests (such as /user/[id]). My current work arounds would be to either use query params (/user?id=blah) or go back to the pages routing. edit: actually query params won't work as the builder still wants to turn it into a static html, so I can only go back to pages I guess... |
Beta Was this translation helpful? Give feedback.
-
Thank you for addressing this problem. I see another significant issue in that – memory overload. There should be the possibility to handle dynamic routes with client-side fetching. Without that option, on large platforms, users would have to download 'gigabytes', with the number growing every day, instead of megabytes from the App Store. Additionally, each new entry force users to update the app to prevent encountering 404 errors. |
Beta Was this translation helpful? Give feedback.
-
Hello everyone! Cross-posting myself from #54393 (comment) so I can get notified about any kind of development in this regard:
Any news of any kind about this? |
Beta Was this translation helpful? Give feedback.
-
hi everyone, guys i am looking for solution for two days , i started thinking to change framework , i have tried everything `"use client"; function Lang({ params }: { params: any} ) { const {sleep, handleSubmitAttribute,object, objectxsById, deleteAttribute, setCurrentLang, attributexs, setAttributes, attributes, user } = useAuth({ middleware: "Guest" });
} // Callback function to receive data from the child
}; const onSubmit = async (e: any) => {
);
} else {
} } const saveX=()=>{ return (
); export default Lang; that is the error `
|
Beta Was this translation helpful? Give feedback.
-
Any update on this? |
Beta Was this translation helpful? Give feedback.
-
🤚 I also am in the boat of needing this -- I need to do I don't work at Vercel, but sadly, I don't see any way this is technically feasible. The output of static builds are individual files. Without knowing the value of individual paths in the data beforehand, Next won't know what paths to create. You could create a system in the framework that generates a You'd have to plug into AWS Route 53 and Cloudfront and wherever else is modifying that request, and have them all account for this logic, and then do that on every hosting provider separately. 😞 I just don't see a way for this to happen. The alternative is to compromise, and turn your dynamic links into URL parameters (which is what I'll have to do). Then, when I export my content, the client side javascript will still be able to pick those values up and use them the way I need. It stinks, but I really don't see any other way. |
Beta Was this translation helpful? Give feedback.
-
This is exactly what I need. In my situation, I'll never use node as backend for anything outside of generating a particular subset(the next app) of a much larger codebase. Our backend is designed for high performance and is entirely written in Rust and entirely consumed via API, mostly via our primary Angular Client, but we have some e-commerce elements we choose to use React/Next for. I'd like to be able to build static pages of existing known content at some specific interval in our deployment process and have our application still seamlessly handle scenarios where those static pages do not exist, etc. There will potentially be tens thousands of those pre-rendered static pages, and hundreds of new additions every day. Deployment directly to CDN is part of our strategy for things like this. Ultimately it seems impossible to use next(app router) to achieve these results, but perhaps our intended use case doesn't fit into vercel's business case. |
Beta Was this translation helpful? Give feedback.
-
would it be supported at least? |
Beta Was this translation helpful? Give feedback.
-
This is a crucial feature. I don't understand why it hasn't been built yet. Especially since it seems pretty straight forward to build. |
Beta Was this translation helpful? Give feedback.
-
It is quite embarrassing that such a widely adopted framework doesn't support for dynamic routes on client side. For now we are working with parameters in the query string, which is very far from ideal. |
Beta Was this translation helpful? Give feedback.
-
This is clearly enshittification. I'm not sure if it's intentional or just selected-for (e.g. deprioritization of this bug in backlog grooming,) but either way, the result is the same. → Vercel is experiencing a conflict-of-interest. On one hand, it maintains an open source package that is now the de facto way of producing React apps; → On the other, it profits from a hosting business; → For some reason, there is a mysterious and undocumented limitation when using NextJS in the only way that does not require hosting. Vercel, please don't be this way! I fought and advocated for your solutions, and now my own credibility is damaged, as we scramble to move from an S3-backed scenario to one that can do dynamic parameters (a feature which, by the way, has been supported in react-router since the Obama administration). There's still time to fix this, though, and this very-downthread comment on a GH discussion is your warning; I'm old enough to have seen firsthand how reputational consequences can salt the earth for a startup. I'm sorry this warning isn't larger, because I agree that the, ah, 'Business Experience' (BX?) of receiving an important warning in this way is not great. Yet I am powerless to do more. You're not powerless, though! |
Beta Was this translation helpful? Give feedback.
-
I'd love for a solution to this. judging by how recent the comments are there has been no progress... |
Beta Was this translation helpful? Give feedback.
-
I have written a proposal to support this feature internally. I hope to share more updates in the coming months 🙏. To share a bit more, the missing part right now is that we need to introduce a concept of "serverless" navigation, i.e., we need to be able to detect that the page you're navigating to might not need a server roundtrip. That'd be useful when you're just using query params as client-side filters, for example. Once we have this, there's just a little bit of plumbing we need to do at compilation time for the static exports mode to then automatically make dynamic params routes always serverless and then we'd be good to go. |
Beta Was this translation helpful? Give feedback.
-
You should put your perspective on vercel's point of view don't just see it from yours. For them static site features doesn't bring much money for than server/backend features. People who use nextjs for static sites mostly just cheapskate with very low or no budget. Vercel spent a lot of money for nextjs. Of course they want to make it more hard for people to use nextjs outside vercel. it doesnt mean they will abandoned this feature, its just not their focus. |
Beta Was this translation helpful? Give feedback.
-
NextJS 15 release and this wasn't fixed yet. 🫤 |
Beta Was this translation helpful? Give feedback.
This comment was marked as off-topic.
This comment was marked as off-topic.
-
Okay, so I have been able to achieve this functionality where we had a Golang backend server serving the static files, the app was generated using SSG, so only routes that existed during build time worked and other threw 404 from the go server. The neat trick that I did was define a basic not-found.js page at the root level (
You can render a custom 404 page if the route actually doesn't exist, after reading the response The only doubt I have is, I don't know how it would behave for a purely static web app, without any server, someone can give this a try and see if it works. |
Beta Was this translation helpful? Give feedback.
-
I hope to see this feature soon released. Now is not possible to produce an SPA with dynamic path and keep the good DX of the App router |
Beta Was this translation helpful? Give feedback.
-
Hi, and sorry to ping your guys @acdlite, @eps1lon, the thing is that we just need an answer from the Next.js team to see if this will ever be developed, we are stuck with this. 🫤 |
Beta Was this translation helpful? Give feedback.
-
This post has received so many comments and votes, but there's still no official response or feedback. How are we supposed to interpret this? Are they just ignoring it? |
Beta Was this translation helpful? Give feedback.
-
We’ve been eagerly waiting for support for dynamic routes in static export mode. This feature would be a game-changer for many of us, enabling cleaner folder-based structures. It feels like a simple yet impactful improvement—please consider prioritizing it. Thank you for all your efforts! |
Beta Was this translation helpful? Give feedback.
-
I wonder why this feature is not yet implemented, I have built a mighty project around next Js only to get stucked here... I wish it can be addressed with immediate effect. |
Beta Was this translation helpful? Give feedback.
-
i just did a massive refactor to use the app router, and run into this after I thought it was done. seriously should be hiilghted in red flashing letters in the docs. |
Beta Was this translation helpful? Give feedback.
-
I've found another workaround, though it's quite a dirty hack.
So far I've only tried this on a couple pages so I can't say if it's production-ready, but it seems to be a good enough stopgap until my project can be migrated to a Next server. Here's the patch I use with patch-package: diff --git a/node_modules/next/dist/build/index.js b/node_modules/next/dist/build/index.js
index 4cb5619..6718515 100644
--- a/node_modules/next/dist/build/index.js
+++ b/node_modules/next/dist/build/index.js
@@ -1294,7 +1294,7 @@ async function build(dir, reactProductionProfiling = false, debugOutput = false,
if (appConfig.revalidate !== 0) {
const hasGenerateStaticParams = workerResult.prerenderedRoutes && workerResult.prerenderedRoutes.length > 0;
if (config.output === 'export' && isDynamic && !hasGenerateStaticParams) {
- throw new Error(`Page "${page}" is missing "generateStaticParams()" so it cannot be used with "output: export" config.`);
+ // throw new Error(`Page "${page}" is missing "generateStaticParams()" so it cannot be used with "output: export" config.`);
}
// Mark the app as static if:
// - It has no dynamic param
diff --git a/node_modules/next/dist/esm/build/index.js b/node_modules/next/dist/esm/build/index.js
index 49ef6e4..146e9ea 100644
--- a/node_modules/next/dist/esm/build/index.js
+++ b/node_modules/next/dist/esm/build/index.js
@@ -1226,7 +1226,7 @@ export default async function build(dir, reactProductionProfiling = false, debug
if (appConfig.revalidate !== 0) {
const hasGenerateStaticParams = workerResult.prerenderedRoutes && workerResult.prerenderedRoutes.length > 0;
if (config.output === 'export' && isDynamic && !hasGenerateStaticParams) {
- throw new Error(`Page "${page}" is missing "generateStaticParams()" so it cannot be used with "output: export" config.`);
+ // throw new Error(`Page "${page}" is missing "generateStaticParams()" so it cannot be used with "output: export" config.`);
}
// Mark the app as static if:
// - It has no dynamic param |
Beta Was this translation helpful? Give feedback.
-
Okay I found a solution for using Dynamic Routes in App Router with output: "export" Works great! First off, create your dynamic page, in this case it will be "post" /app/post/page.tsx"use client"
import { usePathname } from "next/navigation"
export default function PostPage() {
const pathname = usePathname()
const postId = pathname.split('/').pop()
return (
<div>
<h1>Post ID: {postId}</h1>
</div>
)
} Next, link to it from any other page... /app/page.tsx"use client"
import Link from "next/link"
export default function IndexPage() {
return (
<div>
<p>
<Link href="/post/1">
Post 1
</Link>
</p>
<p>
<Link href="/post/2">
Post 2
</Link>
</p>
</div>
)
} Now the kicker, to make these /post/1 and post/2 links actually work! /app/not-found.tsx"use client"
import PostPage from "@/app/post/page"
import { usePathname } from "next/navigation"
export default function NotFound() {
const pathname = usePathname()
if (pathname.includes("/post/")) {
return <PostPage />
}
} Voila, dynamic routes for Next.js App Router using output: "export" |
Beta Was this translation helpful? Give feedback.
-
Goals
Feature Request: Support Dynamic Routes with Dynamic Params in Static Export Mode
Current Behavior
Right now, when we use the
{ output: 'export' }
option to statically pre-generate the app to run without a Node server, we hit a roadblock: dynamic routes like/post/[id]
just can't be created. Yes, we can pre-generate specific pages such as/posts/1
,/posts/2
,/posts/3
, and so on, but if we encounter values not known at build time, we are met with a 404 error. This is quite the hiccup for scenarios demanding static deployment coupled with dynamic data capabilities.Desired Behavior
We're looking to get dynamic routes with variable parameters up and running in static export mode. The vision is to have routes like
/post/[id]
operate without a hitch, avoiding the dreaded 404 error when the ID parameter changes, and allowing individual posts to be fetched client-side. This change would significantly broaden the scope and usefulness of static exports.Non-Goals
What This Feature Request Does Not Aim to Address
Background
Benefits
Flexibility: This feature would open doors for developers to exploit dynamic routes while still enjoying the perks of static export functionalities.
Honoring the Next.js Slogan: Let's make the Next.js slogan "The React Framework" ring true by covering a common SPA use case currently left out in the cold.
Potential Drawbacks
Complexity: While this looks promising, introducing dynamic parameters in static export mode might complicate route management a bit.
Alternatives Considered
Sticking with Static Paths: This option, albeit simpler, severely limits the dynamic functionalities, which are pretty much essential in modern web applications.
Switching to a Different Router: Though this sidesteps some Next.js framework limitations, it comes at the cost of losing many of its benefits and makes the transition between a static site and an SSR application a labor-intensive task.
Additional Context
Embracing dynamic parameters in static export mode would effectively bridge the existing gap between dynamic functionalities and static deployments, offering a flexible and robust solution for developers navigating strict deployment environments.
Proposal
Proposed Solution
Client-Side Rendering (CSR) Enhancements: Let's amp up CSR to facilitate dynamic data fetching based on the dynamic parameters present in the URL — all possible through
useParams()
or parameters relayed to the layout and page components. This isn't uncharted territory; it aligns well with the existing functionalities seen withuseSearchParams()
in client components.Route Fallback Support: Introducing a fallback support system for dynamic routes in static export mode could be a game-changer. This means instead of getting a 404 error, users would land on a predefined fallback page, allowing for the client-side fetching of dynamic parameter data.
Beta Was this translation helpful? Give feedback.
All reactions