Best practice for internationalization routing with <Link>?
Unanswered
Atlantic herring posted this in #help-forum
data:image/s3,"s3://crabby-images/f8b2c/f8b2c8017fcabc9393d56e5d79568fc034a65337" alt="Avatar"
Atlantic herringOP
I have this component:
I’m wondering, what’s the best way to handle routing when internationalizing? The routes should look like:
- /legal/de/termsofservice
- /legal/en/termsofservice
What's the best approach?
<Link href="/legal/termsofservice">
I’m wondering, what’s the best way to handle routing when internationalizing? The routes should look like:
- /legal/de/termsofservice
- /legal/en/termsofservice
What's the best approach?
4 Replies
data:image/s3,"s3://crabby-images/bdd71/bdd714b9dc7c3c77551add1af2a7fca7484903e3" alt="Avatar"
American black bear
// get locale using params or some other way using pathname
const locale = getLocale()
<Link href={`/${locale}/legal/termsofservice`}
This is usually the way. You can take it a step further and create a custom component which automatically prefixes your Link url.
export function LocaleLink({href, children}: {href: string, children: React.ReactNode}) {
// using context or some other way
const locale = getLocale()
return (
<Link href={`${locale}${href}`}>{children}</Link>
)
}
data:image/s3,"s3://crabby-images/79cb1/79cb162e5e4770f8cfa56272e6c072103868524d" alt="Avatar"
Do you need to make the links show the internatiolization? That just seems very hard to maintain
If it's not a requirement, just stick to Middleware rewrites