Error: Importing a component that needs useState. It only works in a Client Component, but none of its parents are marked with use client, so they're Server Components by default.

Shivan M.

The Problem

When using useState in a component in Next.js 13, you might encounter the following error:

You're importing a component that needs useState. It only works in a Client Component, but none of its parents are marked with "use client", so they're Server Components by default.

This error occurs when using the app directory. By default, in Next.js 13, components are marked as Server Components. This means that the HTML is compiled on the server and sent to the client. Server Components shouldn’t contain any code that uses browser-specific APIs, or hooks that are specifically intended for client-side usage (like useState).

The Solution

To resolve this error, you can use the use client directive to mark components as Client Components.

The component below would result in the error in question:

import { useState } from "react"; export default function MyComponent() { const [state, setState] = useState(""); return <></>; }

By adding the use client directive, we resolve the error:

"use client"; import { useState } from "react"; export default function MyComponent() { const [state, setState] = useState(""); return <></>; }

If you want to use a component marked as a Client Component in a Server Component (for example, a third-party library), export the component from the lib folder at the same level as the app directory.

// lib/third-party-component.js "use client"; export * from "@some/library";

Then, in your Server Component:

import { Component } from "../lib/third-party-component"; export default function Page() { return ( // use your component ) }

Get Started With Sentry

Get actionable, code-level insights to resolve Next.js performance bottlenecks and errors.

Run the line of code below to:

  1. Create a free Sentry account

  2. Run the CLI install command to automatically add the Sentry SDK to your project:

    npx @sentry/wizard@latest -i nextjs
  3. Start capturing errors and performance issues

Loved by over 4 million developers and more than 90,000 organizations worldwide, Sentry provides code-level observability to many of the world’s best-known companies like Disney, Peloton, Cloudflare, Eventbrite, Slack, Supercell, and Rockstar Games. Each month we process billions of exceptions from the most popular products on the internet.

Share on Twitter
Bookmark this page
Ask a questionJoin the discussion

Related Answers

A better experience for your users. An easier life for your developers.

    TwitterGitHubDribbbleLinkedinDiscord
© 2024 • Sentry is a registered Trademark
of Functional Software, Inc.