Next.js dynamic routing link component not working
I'm trying to make an online marketplace for plants and gardening accessories for a uni course project and i made the page for the products in a dynamic folder where when you click on a product the link sends the id of the product from the database (which is in supabase) to the product's params so that it pulls all the information of the product from the database and shows it (right now i only coded to show the image) but its not working.
18 Replies
This is the home page from where you can click on learn more to be able to see the product's page
data:image/s3,"s3://crabby-images/ca45f/ca45fe0d2bd54ba72d484e1b351927d85fae9947" alt="No description"
This is the code for the product card in the picture above where the Learn More link links to the dynamic folder where the product page is
data:image/s3,"s3://crabby-images/3ec95/3ec950d1d63a6798000f7da91fcbfb6c3faeb173" alt="No description"
This is the code for the product page itself
data:image/s3,"s3://crabby-images/fe1ca/fe1ca6ac9ae964963203f58fa7e124cc272dea8e" alt="No description"
This is the console error that gets shown
data:image/s3,"s3://crabby-images/6ef46/6ef4623e9b3422d1b34a0aabbcd7b3f857900542" alt="No description"
If i try to just show the id that gets passed to the params
data:image/s3,"s3://crabby-images/0509f/0509f8aef1dd2a5e849f7a5de711624a842756f6" alt="No description"
It shows this id regardless of which product i click on
data:image/s3,"s3://crabby-images/dc168/dc168f2bf5f26b06e7477a3b85f3301b6a822609" alt="No description"
data:image/s3,"s3://crabby-images/151b1/151b1b69bdefaf99e0723e4e67267a1fcd57c8d4" alt="No description"
which isnt the id for any of the products in the database
However, if i manually copy and paste the id of the product from the database to the browser after product/, it shows the picture of the product
data:image/s3,"s3://crabby-images/91779/91779c677bc074f2e73b62feedca0b1b227e4658" alt="No description"
can you specify your nextjs version
in nextjs v15+
you have to await
params
and searchParams
before you can access their values
this is what is causing the error
atleast according to the messageRouting: Dynamic Routes | Next.js
Dynamic Routes can be used to programmatically generate route segments from dynamic data.
THe params is working properly. If i copy/paste the id of one of the products in the url after products/ , it shows me all the data of that product properly.
data:image/s3,"s3://crabby-images/f6cec/f6cec3d72038dcab0235ae5e211093056c6d487f" alt="No description"
The problem is that the next link isnt passing the id of the product to the params, just generating a random one
And since that random param id does not exist in the database, the page returns empty information
data:image/s3,"s3://crabby-images/73b73/73b7346eaf3046989032c4fa10296cf477a16682" alt="No description"
issue is probably somewhere here
data:image/s3,"s3://crabby-images/aa9a3/aa9a3acad6da6b6f298bc605ec7abd3d7d1e257f" alt="No description"
brother
use a template literal
Solution
replace the
"
with backticksIt WORKS!
THANK YOU BROTHER
in this case
you're navigating to this exact url, inside the quotes. It then tries to convert the ${id} into a url friendly form by conversion which results in the weird url
gl on your project
you can mark this question as solved by right clicking on the solution > apps > mark solution