>웹 프론트엔드 >JS 튜토리얼 >Next.js 13의 \'use client\' 지시문 이해

Next.js 13의 \'use client\' 지시문 이해

Susan Sarandon
Susan Sarandon원래의
2024-09-23 14:31:20344검색

Understanding the

Next.js 13에서는 새로운 앱 디렉토리가 도입되면서 구성 요소가 렌더링되는 방식이 크게 바뀌었습니다. 기본적으로 앱 디렉터리의 구성 요소는 서버에서 렌더링되는 서버 구성 요소로 처리됩니다. 이 기본 동작은 성능 및 데이터 가져오기에 최적화되어 있지만 클라이언트 측 상호 작용에 있어서는 제한이 따릅니다. 이 문제를 해결하기 위해 Next.js 13에서는 구성 요소나 파일을 클라이언트측 JavaScript로 명시적으로 지정하는 "use client" 지시문을 도입했습니다.

"클라이언트 사용"을 사용하는 이유

클라이언트측 상호작용

구성요소가 브라우저와 상호작용해야 하는 경우(예: 클릭과 같은 사용자 이벤트 처리 또는 로컬 저장소 액세스) '클라이언트 사용'으로 표시되어야 합니다. 이는 서버 구성 요소가 브라우저 API, 이벤트 리스너 또는 기타 클라이언트 측 기능에 액세스할 수 없기 때문입니다.

후크 및 상태 관리

useState, useEffect, useRef 등과 같은 후크는 클라이언트 구성 요소에서만 사용할 수 있습니다. 따라서 이러한 후크를 사용할 때는 파일이나 구성 요소에 "클라이언트 사용"을 표시해야 합니다.

이벤트 처리

React 이벤트 핸들러(예: onClick, onChange)를 사용하려면 구성 요소가 브라우저에서 실행되어야 합니다. 결과적으로 해당 구성 요소는 클라이언트 구성 요소로 표시되어야 합니다.

사용처

클라이언트 측에서 렌더링해야 하는 구성 요소에 대해 파일 상단에 "클라이언트 사용"을 배치합니다.

"use client";

import { useState } from "react";

export default function MyComponent() {
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>{count}</p>
      <button onClick={() => setCount(count + 1)}>Increment</button>
    </div>
  );
}

핵심사항

최상위 지침

가져오기나 다른 코드 이전에 파일 상단에 배치해야 합니다.

범위

파일에 "클라이언트 사용"을 추가하면 해당 파일 내의 모든 구성 요소가 클라이언트 구성 요소가 됩니다. 즉, 번들로 묶여 브라우저에서 실행됩니다.

선택적 사용

성능이나 데이터 가져오기 측면에서 서버 구성 요소가 더 효율적이므로 꼭 필요한 경우에만 사용하는 것이 좋습니다.

요약

요약하자면, 기본적으로 서버 측 렌더링 및 최적화를 선호하는 프레임워크에서 클라이언트 측 대화형 구성 요소를 구축하려는 경우 "클라이언트 사용" 지시문이 필요합니다. 구성 요소를 클라이언트 측으로 명시적으로 표시하면 후크 및 이벤트 처리와 같은 React 클라이언트 측 기능의 모든 기능을 활용하는 동시에 서버 측 렌더링의 성능 이점을 누릴 수 있습니다.

이러한 균형을 통해 개발자는 필요에 따라 서버측 렌더링과 클라이언트측 렌더링을 모두 활용하여 고도로 대화형이고 성능이 뛰어난 웹 애플리케이션을 만들 수 있습니다.

위 내용은 Next.js 13의 \'use client\' 지시문 이해의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.