찾다
개발 도구composerReact Context Composer를 캡슐화하기 위한 세부 단계(공유)

이 글은 composer튜토리얼 칼럼에서 React Context Composer를 캡슐화하는 방법을 단계별로 소개하기 위해 작성한 글입니다. 필요한 친구들에게 도움이 되길 바랍니다!

React Context Composer를 단계별로 어떻게 캡슐화하나요?

Motivation

React에는 Redux, Mobx, Recoil 등 많은 상태 관리 솔루션이 있습니다. 아직까지 Redux만 경험해 봤기 때문에 아직은 조금 번거롭다고 생각합니다. 나는 일반적으로 많은 Hook을 작성하기 때문에 상태를 쉽게 분할하고 결합할 수 있는 useContext 후크와 함께 Context Provider를 사용하는 것을 선호합니다. 여기서는 각 상태 관리 솔루션의 장단점을 논의하지 않고 Context를 사용할 때 발생하는 다중 계층 중첩 문제에 중점을 둡니다.

아래 사진은 제가 최근 작성하고 있던 taro + React Hooks + TS 프로젝트에서 추출한 코드의 일부입니다. 일부 전역 상태를 분할한 다음(분할의 목적은 불필요한 다시 렌더링을 줄이는 것임) 중첩했습니다. 이런 글을 쓰다 보면 콜백 지옥에 지배당하는 느낌이 생각나는데, 그게 굉장히 불편해요. 그래서 고차 부품을 직접 봉인하고 구조를 글쓰기 측면에서 '평탄화'하는 방법을 생각했습니다.

<LoadingContext.Provider value={{ loading, setLoading }}>
  <UserDataContext.Provider value={{ name: "ascodelife", age: 25 }}>
    <ThemeContext.Provider value={"light"}>
    {/* ....more Providers as long as you want */}
    </ThemeContext.Provider>
  </UserDataContext.Provider>
</LoadingContext.Provider>

가장 쉬운 솔루션

여기서 저는 ReduceRight를 사용하여 Provider 중첩을 완료하는 첫 번째 솔루션을 빠르게 작성했습니다.

여기서 Reduce 대신에 ReduceRight를 사용한 이유는 외부 레이어에서 내부 레이어로의 쓰기 순서에 더 익숙하기 때문입니다.

// ContextComposer.tsx
import React from &#39;react&#39;;
type IContextComposerProps = {
  contexts: { context: React.Context<any>; value: any }[];
};
const ContextComposer: React.FC<IContextComposerProps> = ({ contexts, children }) => {
  return (
    <>
      {contexts.reduceRight((child, parent) => {
        const { context, value } = parent;
        return <context.Provider value={value}>{child}</context.Provider>;
      }, children)}
    </>
  );
};
export default ContextComposer;
// App.tsx
<ContextComposer
  contexts={[
    { context: ThemeContext, value: "light" },
    { context: UserDataContext, value: { name: "ascodelife", age: 25 } },
    { context: LoadingContext, value: { loading, setLoading } },
  ]}>
    { children }
</ContextComposer>

실제 경험을 통해 사용할 수는 있지만 개발 경험이 조금 더 나쁘다는 것을 알았습니다. 문제는 구성 요소가 매개 변수를 입력할 때 전달된 값이 any 유형이라는 것입니다. 이는 ts의 정적 유형 확인이 중단됨을 의미합니다. 매개변수를 전달할 때 값에 대해 정적 유형 검사가 수행되지 않으므로 코드를 입력할 때 코드 프롬프트가 표시되지 않을 뿐만 아니라 상대적으로 낮은 수준의 런타임 오류가 발생할 수도 있습니다. 나쁜 리뷰!

React.cloneElement()를 기반으로 한 변환 계획

위 솔루션을 변환하기 위해 상대적으로 인기가 없지만 사용하기 쉬운 함수인 React.cloneElement()를 발견했습니다. 이 함수에 대해 주목할 만한 점은 많지 않습니다. 주로 세 가지 입력 매개변수를 살펴보세요. 첫 번째는 상위 요소이고, 두 번째는 상위 소품이고, 세 번째는 나머지 매개변수입니다. 첫 번째 매개변수. 이를 제외한 다른 모든 값은 선택사항입니다.

예:

<!-- 调用函数 -->
React.cloneElement(<div/>,{},<span/>);
<!-- 相当于创建了这样一个结构 -->
<div> 
    <span></span>
</div>

그런 다음 변환을 시작해 보겠습니다. ReduceRight 프레임은 변경되지 않은 상태로 유지됩니다. 입력 매개변수 유형과 ReduceRight 콜백을 변경합니다.

// ContextComposer.tsx
import React from &#39;react&#39;;
type IContextComposerProps = {
  contexts: React.ReactElement[];
};
const ContextComposer: React.FC<IContextComposerProps> = ({ contexts, children }) => {
  return (
    <>
      {contexts.reduceRight((child, parent) => {
        return React.cloneElement(parent,{},child);
      }, children)}
    </>
  );
};
export default ContextComposer;
// App.tsx
<ContextComposer
  contexts={[
      <ThemeContext.Provider value={"light"} />,
      <UserDataContext.Provider value={{ name: "ascodelife", age: 25 }} />,
      <LoadingContext.Provider value={{ loading, setLoading }} />,
  ]}>
    { children }
</ContextComposer>

변환 후 매개변수를 전달하면 실제로 컴포넌트를 생성하는 것처럼 보입니다(물론 실제로 컴포넌트가 생성되지만 컴포넌트 자체는 가상 Dom에 렌더링되지 않습니다. 실제로 렌더링되는 것은 생성된 이후입니다.) 복제되었습니다.) 동시에 우리가 방금 집중했던 값의 정적 유형 검사 문제도 해결되었습니다.

팁: React.cloneElement(parent,{},child)는 React.cloneElement(parent,{children:child})와 동일합니다. 이유를 알고 계시나요?

관련 자료

소스 코드가 github(https://github.com/ascodelife/react-context-provider-composer)에 동기화되었습니다.

npm Warehouse(https://www.npmjs.com/package/@ascodelife/react-context-provider-composer)에도 패키징되어 있으니 직접 경험해 보세요.

위 내용은 React Context Composer를 캡슐화하기 위한 세부 단계(공유)의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명
이 기사는 juejin에서 복제됩니다. 침해가 있는 경우 admin@php.cn으로 문의하시기 바랍니다. 삭제
작곡가 : PHP 프로젝트 개발 간소화작곡가 : PHP 프로젝트 개발 간소화Apr 15, 2025 am 12:08 AM

Composer는 PHP 프로젝트 개발 단계를 단순화합니다. 1) Composer.json의 "laravel/framework"추가와 같은 종속성 추가; "^8.0"; 2) 네임 스페이스 및 클래스 경로를 정의하여 자동로드, autoload.php 파일을 생성합니다. 3) ComposerDump-Autoload-O 및 ComposerInstall을 사용하여 성능 최적화-DEV-OPTIMIZE AUTOLOADER 명령. 이러한 단계를 통해 개발자는보다 효율적이며 일반적인 실수를 피할 수 있습니다.

작곡가 자격 증명 : 누군가를 작곡가로 만드는 이유는 무엇입니까?작곡가 자격 증명 : 누군가를 작곡가로 만드는 이유는 무엇입니까?Apr 14, 2025 am 12:13 AM

작곡가가되는 주요 요소는 다음과 같습니다. 1. 음악 이론 마스터 링, 2. 창의적이고 독창적, 3. 기술 능력, 4. 감정을 표현하고 이야기를 할 수있는 이야기, 5. 문화적, 역사적 배경 이해, 6. 이러한 요소가 함께 작곡가의 정체성과 능력을 구성합니다.

작곡가가되는 길 : 실용 가이드작곡가가되는 길 : 실용 가이드Apr 13, 2025 am 12:11 AM

작곡가가되는 단계에는 다음이 포함됩니다. 1. 메모, 리듬, 하모니 및 멜로디와 같은 음악의 기본 요소를 마스터합니다. 2. AbletonLive와 같은 적절한 기술 도구를 선택하십시오. 3. 영감 획득, 개념, 작문, 수정 및 개선을 포함하여 작곡 과정을 이해합니다. 4. 간단한 멜로디 생성으로 시작하고 조화와 같은 복잡한 기술을 점차적으로 시도하십시오. 5. 메모 선택 및 리듬 배열과 같은 디버깅 기술을 통해 일반적인 문제를 해결합니다. 6. 템플릿 사용, 버전 제어 및 협업과 같은 성능 최적화 및 모범 사례를 적용합니다.

작곡가 : 강력한 PHP 응용 프로그램 구축의 열쇠입니다작곡가 : 강력한 PHP 응용 프로그램 구축의 열쇠입니다Apr 12, 2025 am 12:05 AM

Composer는 종속성 관리를 단순화하고 개발 효율성 및 코드 품질을 향상시키기 때문에 강력한 PHP 응용 프로그램을 구축하는 핵심 도구입니다. 1) Composer는 Composer.json 파일을 통해 프로젝트 종속성을 정의하고 이러한 종속성을 자동으로 다운로드하고 관리합니다. 2) Composer.lock 파일을 생성하여 종속성 버전이 벤더/autoload.php를 통해 자동으로로드되도록합니다. 3) 사용의 예에는 로그 라이브러리 추가와 같은 기본 사용 및 버전 제약 조건 및 환경 변수 관리와 같은 고급 사용법이 포함됩니다. 4) 일반적인 오류 디버깅 기술에는 의존성 충돌 및 네트워크 문제 처리가 포함됩니다. 5) 성능 최적화 제안에는 Composer.Lock 파일 사용 및 자동로드 최적화가 포함됩니다.

작곡가 전문 지식 : 누군가를 숙련하게 만드는 것작곡가 전문 지식 : 누군가를 숙련하게 만드는 것Apr 11, 2025 pm 12:41 PM

작곡가를 사용할 때 능숙 해지려면 다음과 같은 기술을 마스터해야합니다. 1. Composer.json 및 Composer.lock Files, 2. Composer의 작동 방식 이해, 3. Master Composer의 명령 줄 도구, 4. 기본 및 고급 사용법 이해, 5. 일반적인 오류 및 디버깅 기술에 익숙하고, 사용법을 최적화하고 모범 사례를 최적화해야합니다.

작곡가는 무엇을하고 있습니까?작곡가는 무엇을하고 있습니까?Apr 08, 2025 am 12:19 AM

Composer는 프로젝트 종속성을 선언, 다운로드 및 관리하는 데 사용되는 PHP의 종속성 관리 도구입니다. 1) Composer.json 파일을 통한 종속성 선언, 2) ComposerInstall 명령을 사용하여 종속성을 설치하고 3) 종속성 트리를 구문 분석하고 Packagist에서 다운로드하십시오.

앱 작곡가 란 무엇입니까?앱 작곡가 란 무엇입니까?Apr 07, 2025 am 12:07 AM

AppComposer는 응용 프로그램을 구축하고 관리하는 도구입니다. 1) 사전 정의 된 구성 요소를 드래그하고 구성하여 응용 프로그램 개발을 단순화하고 효율성을 향상시킵니다. 2) 개발자는 구성 요소를 정의하고 인터페이스를 결합하고 비즈니스 로직을 정의하며 궁극적으로 응용 프로그램을 렌더링 할 수 있습니다. 3) 작업 관리 및 조건부 렌더링과 같은 기본 및 고급 사용을 지원하여 유연한 응용 프로그램을 구축하는 데 도움이됩니다.

작곡가는 무엇을 사용합니까?작곡가는 무엇을 사용합니까?Apr 06, 2025 am 12:02 AM

Composer는 PHP의 종속성 관리 도구입니다. 작곡가를 사용하는 핵심 단계는 다음과 같습니다. 1) Composer.json의 종속성 선언 "Stripe/Stripe-PHP": "^7.0"; 2) ComposerInstall을 실행하여 종속성을 다운로드하고 구성합니다. 3) Composer.lock 및 Autoload.php를 통해 버전 및 자동로드를 관리합니다. 작곡가는 종속성 관리를 단순화하고 프로젝트 효율성과 유지 관리를 향상시킵니다.

See all articles

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

인기 기사

R.E.P.O. 에너지 결정과 그들이하는 일 (노란색 크리스탈)
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 최고의 그래픽 설정
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 아무도들을 수없는 경우 오디오를 수정하는 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. 채팅 명령 및 사용 방법
4 몇 주 전By尊渡假赌尊渡假赌尊渡假赌

뜨거운 도구

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse용 SAP NetWeaver 서버 어댑터

Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

mPDF

mPDF

mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Dreamweaver Mac版

Dreamweaver Mac版

시각적 웹 개발 도구

ZendStudio 13.5.1 맥

ZendStudio 13.5.1 맥

강력한 PHP 통합 개발 환경

MinGW - Windows용 미니멀리스트 GNU

MinGW - Windows용 미니멀리스트 GNU

이 프로젝트는 osdn.net/projects/mingw로 마이그레이션되는 중입니다. 계속해서 그곳에서 우리를 팔로우할 수 있습니다. MinGW: GCC(GNU Compiler Collection)의 기본 Windows 포트로, 기본 Windows 애플리케이션을 구축하기 위한 무료 배포 가능 가져오기 라이브러리 및 헤더 파일로 C99 기능을 지원하는 MSVC 런타임에 대한 확장이 포함되어 있습니다. 모든 MinGW 소프트웨어는 64비트 Windows 플랫폼에서 실행될 수 있습니다.