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.

Presentify

Take your presentation to the next level.

FaceScreen

Put your face and name on your screen.

KeyScreen

Show keypresses on your screen.

ToDoBar

Your to-dos on your menu bar.

SimpleFill

Fill forms using your right-click menu.

IconSim

Preview your Mac app icons.

Ram Patra Published on November 17, 2024
Image placeholder

Keep reading

If this article was helpful, others might be too

question nextjs front-end December 21, 2024 Difference between router in next/navigation and next/router in Next.js?

In Next.js, there are two main ways to handle routing programmatically:

question nextjs react July 18, 2024 How to programmatically navigate to a page in Next.js?

In Next.js, you can programmatically navigate to different pages using the useRouter hook from the next/navigation module. This hook provides a convenient way to navigate between pages within your Next.js application. Below is an example demonstrating how to use the useRouter hook to programmatically navigate to another page.

question eslint nextjs November 14, 2024 How to disable ESLint in a Nextjs project?

Although it is highly advisable to enable ESLint at all times, if you do not want ESLint to run during next build, you can set the eslint.ignoreDuringBuilds option in next.config.js to true like below:

Like my work?

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