F-Lab
🚀
상위권 IT회사 합격 이력서 무료로 모아보기

리액트 포털을 활용한 모달 구현 방법

writer_thumbnail

F-Lab : 상위 1% 개발자들의 멘토링

AI가 제공하는 얕고 넓은 지식을 위한 짤막한 글입니다!



리액트 포털이란?

리액트 포털(React Portal)은 부모 컴포넌트의 DOM 계층 구조 외부에 있는 DOM 노드로 자식을 렌더링할 수 있게 해주는 리액트의 고급 기능입니다. 이를 통해 모달, 툴팁, 알림과 같은 UI 요소를 루트 DOM 노드 외부에 렌더링할 수 있습니다.

왜냐하면 리액트 컴포넌트 트리 내에서 렌더링되는 UI 요소들은 부모 컴포넌트의 스타일과 위치에 영향을 받기 때문입니다.

리액트 포털을 사용하면 이러한 제약에서 벗어나, 애플리케이션의 UI 구조를 더 유연하게 설계할 수 있습니다.

특히 모달과 같은 요소를 구현할 때 리액트 포털은 중첩된 컴포넌트 구조에서 발생할 수 있는 스타일 충돌 문제를 해결해 줍니다.

이 글에서는 리액트 포털을 활용한 모달 구현 방법에 대해 알아보겠습니다.



리액트 포털을 사용한 모달 구현 기본

리액트 포털을 사용하여 모달을 구현하기 위해서는 먼저 ReactDOM에서 제공하는 createPortal 메서드를 사용합니다. 이 메서드는 첫 번째 인자로 렌더링할 자식 컴포넌트를, 두 번째 인자로는 이 컴포넌트가 마운트될 DOM 노드를 받습니다.

왜냐하면 createPortal 메서드를 통해 생성된 컴포넌트는 부모 컴포넌트와 독립적으로 렌더링되기 때문입니다.

모달 컴포넌트를 구현할 때는 일반적으로 애플리케이션의 루트 레벨에 모달을 렌더링할 DOM 노드를 준비하고, 이 노드를 createPortal의 두 번째 인자로 전달합니다.

이렇게 하면 모달 컴포넌트는 애플리케이션의 다른 UI 요소와 겹치지 않으면서도, 애플리케이션의 상태와 데이터를 공유할 수 있습니다.

다음은 리액트 포털을 사용한 모달 구현의 기본적인 예시 코드입니다.

    import React from 'react';
    import ReactDOM from 'react-dom';

    const Modal = ({ isOpen, children }) => {
        if (!isOpen) return null;

        return ReactDOM.createPortal(
            <div className='modal'>
                {children}
            </div>,
            document.getElementById('modal-root')
        );
    };

    export default Modal;


모달 스타일링과 상태 관리

리액트 포털을 사용한 모달 구현에서 중요한 부분 중 하나는 모달의 스타일링입니다. 모달 컴포넌트는 애플리케이션의 다른 부분과 격리되어 렌더링되므로, 모달의 스타일은 독립적으로 관리되어야 합니다.

왜냐하면 모달의 스타일이 애플리케이션의 다른 부분에 영향을 주지 않도록 하기 위해서입니다.

또한, 모달의 상태 관리도 중요한데, 모달이 열리고 닫히는 상태는 애플리케이션의 다른 상태와 연동되어 관리될 수 있습니다. 이를 위해 리액트의 상태 관리 기능을 활용할 수 있습니다.

모달을 열고 닫는 기능은 버튼 클릭과 같은 사용자 인터랙션에 의해 트리거될 수 있으며, 이러한 상태 변화는 애플리케이션의 UI 흐름을 자연스럽게 만듭니다.

다음은 모달의 상태 관리와 스타일링을 포함한 예시 코드입니다.

    import React, { useState } from 'react';
    import ReactDOM from 'react-dom';
    import './Modal.css'; // 모달 스타일 시트

    const App = () => {
        const [isOpen, setIsOpen] = useState(false);

        return (
            <div>
                <button onClick={() => setIsOpen(true)}>Open Modal</button>
                <Modal isOpen={isOpen} onClose={() => setIsOpen(false)}>
                    <h1>Modal Title</h1>
                    <p>This is a modal content.</p>
                    <button onClick={() => setIsOpen(false)}>Close</button>
                </Modal>
            </div>
        );
    };

    export default App;


결론

리액트 포털은 모달과 같은 UI 요소를 효과적으로 구현할 수 있는 강력한 기능입니다. 이를 통해 애플리케이션의 UI 구조를 더 유연하게 설계할 수 있으며, 사용자 경험을 향상시킬 수 있습니다.

왜냐하면 리액트 포털을 사용하면 모달이 애플리케이션의 다른 요소와 겹치지 않고, 독립적으로 스타일링과 상태 관리가 가능하기 때문입니다.

이 글을 통해 리액트 포털을 활용한 모달 구현 방법에 대해 알아보았습니다. 리액트 포털을 사용하여 더 나은 사용자 인터페이스를 구현해 보세요.

리액트 포털은 단순히 모달을 넘어서 다양한 UI 요소를 구현하는 데 있어 유용한 도구입니다. 올바르게 활용한다면, 애플리케이션의 가능성을 한층 더 확장할 수 있습니다.

ⓒ F-Lab & Company

이 컨텐츠는 F-Lab의 고유 자산으로 상업적인 목적의 복사 및 배포를 금합니다.

조회수
F-Lab
소개채용멘토 지원
facebook
linkedIn
youtube
instagram
logo
(주)에프랩앤컴퍼니 | 사업자등록번호 : 534-85-01979 | 대표자명 : 박중수 | 전화번호 : 1600-8776 | 제휴 문의 : info@f-lab.kr | 주소 : 서울특별시 강남구 테헤란로63길 12, 438호 | copyright © F-Lab & Company 2025