Loading...

How to define metadata in a client component in Nextjs?

question nextjs react
Ram Patra Published on November 17, 2024

Nextjs does not allow defining the metadata object in client components. There are a couple of ways to resolve this problem. I will be talking about two of them here.

In case you aren’t aware of this, the new metadata object looks like below:

import type { Metadata } from "next";

export const metadata: Metadata = {
  title: "",
  description: "",
};

Now, the most obvious way would be to extract the code that needs client components and put it another file. This way you can remove the "use client" from your page.tsx file and put it in your new file where you have the extracted code.

But if you’re not willing to do this for whatever reason, an easier way would be to just place a simple layout.tsx file in the same directory as your page.tsx.

I am sharing a sample layout.tsx file from one of my projects:

import type { Metadata } from "next";


export const metadata: Metadata = {
  title: "Black Friday Deals 2024 - macOS apps",
  description: "A directory of macOS apps that are free or 50% off for a limited time.",
};

export default function BfdLayout({
  children,
}: {
  children: React.ReactNode
}) {
  return (
    <>
      {children}
    </>
  )
}

The above approach doesn’t need you to modify your page.tsx.

Take your presentation to the next level.

Put your face and name on your screen.

Your to-dos on your menu bar.

Fill forms using your right-click menu.

Ram Patra Published on November 17, 2024
Image placeholder

Keep reading

If this article was helpful, others might be too

question nextjs vercel March 1, 2025 Three ways to disable Image Optimization in Vercel

If you’re using the free tier of Vercel, like I do for some of my small side projects, you will get the 402 Payment Required error eventually when loading images. This is because you have hit the Image Optimization limit of the free plan. The solution to this is to disable Vercel’s Image Optimization, or to host the images elsewhere, or to upgrade to their Pro plan.

question nextjs react July 9, 2024 How to create global types in Typescript in a Next.js app?

The env.d.ts file is typically used for global type declarations, especially for environment variables and other globally available types. This file is automatically included in the TypeScript compilation if it’s referenced in tsconfig.json.

question nextjs react July 19, 2024 How to get the current path in Next.js?

To get the current path in a Next.js application, you can use the usePathname hook from next/navigation module. This hook allows you to access the current pathname within your components. Here’s how you can use it:

Like my work?

Please, feel free to reach out. I would be more than happy to chat.