The best way of dynamic breadcrumbs?
Answered
Cape lion posted this in #help-forum
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
I am wondering what is the best approach for dynamic breadcrumbs.
For example i have a
I would like to conver it to a title of a post.
I have found two interesting articles about it:
https://www.openstatus.dev/blog/dynamic-breadcrumb-nextjs
https://www.gcasc.io/blog/next-dynamic-breadcrumbs
Whick one is better? Or maybe there is orher way of handling breadcrumbs?
For example i have a
/dashboard/posts/[id]
and instead of displaying real id like (g213g-51wtrw... lol) I would like to conver it to a title of a post.
I have found two interesting articles about it:
https://www.openstatus.dev/blog/dynamic-breadcrumb-nextjs
https://www.gcasc.io/blog/next-dynamic-breadcrumbs
Whick one is better? Or maybe there is orher way of handling breadcrumbs?
Answered by adam.birds
@Cape lion I don't see any issue with the way shown here in https://www.openstatus.dev/blog/dynamic-breadcrumb-nextjs
21 Replies
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
@Cape lion I don't see any issue with the way shown here in https://www.openstatus.dev/blog/dynamic-breadcrumb-nextjs
Answer
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
That seems a cleaner approach to me than the other.
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
im not looking for issues, just wondering if this is proper way and know others opinions
but one thing is not clear for me
what about
what about
@breadcrumbs/dogs
is it not going to error out? there is nothing about creating page.tsx in /dogs or somethingdata:image/s3,"s3://crabby-images/27f6f/27f6feeedcbe5b168961745f0c3c92a4e542666a" alt="Image"
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
The @ is to do with parallel routes. - https://nextjs.org/docs/app/building-your-application/routing/parallel-routes
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
im getting error with such structure
data:image/s3,"s3://crabby-images/e55e7/e55e7d46cb233133848e97e6e60c9f85d3d0113f" alt="Image"
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
You don't have to use the @ sign
I'm just reading through it m ore to understand it
Did you edit the layout file?
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
Yes, my layout.tsx for /dashboard has
<div className="container mx-auto">
{breadcrumb}
{children}
</div>
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
Show the error you are getting.
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
Ok, nvm 😐 I had
/posts
instead of /dashboard/posts
but it makes me think that in such way of creating breadcrumb i need to manually re-create the structure of whole breadcrumbs list
i mean in example of "Dogs and Cats pages" from the first link. He is re-writing all the breadcrumbs once again
so if the structure of the pages (links) change i need to remember to manually change my breadcrumbs
export default async function BreadcrumbSlot({
params,
}: {
params: { postId: string };
}) {
const { postId } = await params;
const res = await getPostById(postId);
return (
<Breadcrumb>
<BreadcrumbList>
<BreadcrumbItem>
<BreadcrumbLink href="/dashboard">Dashboard</BreadcrumbLink>
</BreadcrumbItem>
<BreadcrumbSeparator />
<BreadcrumbItem>
<BreadcrumbLink href="/dashboard/posts">Posts</BreadcrumbLink>
</BreadcrumbItem>
<BreadcrumbSeparator />
<BreadcrumbItem>
<BreadcrumbPage className="capitalize">
{res.data?.title}
</BreadcrumbPage>
</BreadcrumbItem>
</BreadcrumbList>
</Breadcrumb>
);
}
is there any better solution for it? Instead of rewriting whole list?
data:image/s3,"s3://crabby-images/7e7db/7e7db2ec2294169e033e88b6a96f8e704347327b" alt="Avatar"
I don't think there would without basing the breadcrumbs off the URL but then you would be looking at the ID instead of the title again.
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
Hmm, ok. Maybe there is an option with creating reusable component for breadcrumbs where the whole list will be created by url - paths and the last element would be a prop that can be passed in
@breadcrumb/posts/[postId]
data:image/s3,"s3://crabby-images/6d868/6d868490db02c60a2c8f935e1fc13af45c830f70" alt="Avatar"
Cape lionOP
Ok, i will try it 🙂 Thank you for your time!