React 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 'react'; 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 'react'; 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 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











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

Composer는 PHP 프로젝트의 종속성을 관리하는 데 사용되며 Orchestrator는 마이크로 서비스 또는 컨테이너화 된 응용 프로그램을 관리하고 조정하는 데 사용됩니다. 1. Composer.json 파일을 통해 PHP 프로젝트의 종속성을 선언하고 관리합니다. 2. Orchestrator는 구성 파일 (예 : Kubernetes의 Yaml 파일)을 통해 서비스의 배포 및 확장을 관리하여 고 가용성 및로드 밸런싱을 보장합니다.

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

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

Composer는 Android의 SurfaceFlinger 서비스의 일부이며 여러 그래픽 레이어를 최종 디스플레이 버퍼로 합성하는 일을 담당합니다. 1) 그래픽 계층을 수집, 2) 그래픽 레이어를 정렬하십시오.

작곡가는 음악을 만들고, 감정을 표현하고, 이야기를 전하고, 음악을 통해 아이디어를 전달하는 사람들입니다. 작곡가의 작업에는 다음이 포함됩니다. 1. 개념 : 작업의 주제와 스타일을 결정합니다. 2. 창조 : 예비 음악 구조를 형성하기 위해 멜로디와 조화를 구성한다. 3. 실험 : 기기 또는 소프트웨어를 통한 작업의 오디션 및 조정; 4. 개선 : 만족할 때까지 오디션 결과에 따라 수정 및 개선.

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

Composerai는 개발 효율성과 품질을 향상시키기 위해 코드를 생성하고 최적화하기위한 인공 지능 기반 도구입니다. 그 기능에는 다음이 포함됩니다. 1. 코드 생성 : 요구 사항에 따라 표준을 충족하는 코드 스 니펫 생성. 2. 코드 최적화 : 기존 코드를 분석하여 최적화 제안을하십시오. 3. 자동 테스트 : 테스트 케이스를 생성하여 코드 품질을 보장합니다.
