inflearn logo
강의

講義

知識共有

[React/VanillaJS] UI要素を直接作成する Part 2

基本環境設定 (2/2) コンポーネント作成

테일윈드로 포탈로 모달작성시 뒤에 클릭이 안됩니다

解決済みの質問

316

nyamnyamgood

投稿した質問数 36

1

<div
      id='modalRoot'
      ref={ref}
      className='fixed inset-0 z-100 flex flex-col items-center justify-center'
     
    >
      {children}
    </div>

테일 윈드로 선생님 모달 포탈로만드는것 해보고있는데.
뒤에 클릭이 안되요

pointer-events-none 쓰지말고 하는법이 없을까요?!

일단은
아래처럼 쓰고잇긴한데 ㅠㅠ 먼가 ...

'use client';
import React, { useEffect, useRef } from 'react';
import { useModalStore } from '@/shared/models/modal/stores/modalStore';

const mutationObserverOption: MutationObserverInit = {
  childList: true,
  subtree: false,
};

/**
 * 모달 컴포넌트를 렌더링하기 위한 전역 컨테이너 프로바이더입니다.
 * 모달이 열려 있을 때 body 요소에 'no-scroll' 클래스를 토글하여 스크롤을 비활성화합니다.
 *
 * @param {React.ReactNode} children - 모달 루트 내부에 렌더링할 자식 요소
 * @returns {JSX.Element} 모달 루트 프로바이더
 */
const ModalRootProvider: React.FC<{ children: React.ReactNode }> = ({
  children,
}) => {
  const ref = useRef<HTMLDivElement>(null);
  const { openedModalTypes, closeModal } = useModalStore();
  // const isModalOpen = openedModalTypes.length > 0;

  useEffect(() => {
    let observer: MutationObserver;

    /**
     * MutationObserver를 사용하여 모달 루트 컨테이너의 자식 요소 변경을 감지합니다.
     * 모달이 열려 있는 경우 body 요소에 'no-scroll' 클래스를 추가하고, 모달이 닫혀 있는 경우 클래스를 제거합니다.
     */
    if (ref.current) {
      observer = new MutationObserver(() => {
        const size = ref.current?.childNodes.length || 0;
        document.body.classList.toggle('no-scroll', size > 0);

        ref.current!.classList.toggle('bg-black/50', size > 0);
        ref.current!.style.pointerEvents = size > 0 ? 'auto' : 'none';
      });
      observer.observe(ref.current, mutationObserverOption);
    }

    // 컴포넌트 언마운트 시 MutationObserver 연결을 해제합니다.
    return () => {
      observer.disconnect();
    };
  }, []);

  return (
    <div
      id='modalRoot'
      ref={ref}
      className='fixed inset-0 z-100 flex flex-col items-center justify-center pointer-events-none'
      // onClick={handleOutsideClick}
    >
      {children}
    </div>
  );
};

export default ModalRootProvider;

react typescript dom ui vanilla-js

回答 2

1

jaenam

  1. modalRoot는 z-index를 확보하기 위해 html body의 가장 마지막에 위치시키는 것이 바람직합니다.

<body>
  <ModalProvider />
  {children}
  <ModalRoot />
</body>
  1. modalRoot에는 스타일이 불필요합니다.

    <div id="modalRoot" ref={ref} />

1

nyamnyamgood

선생님 정말 도움이되었어요 정말감사합니다!
선생님 다른강의도 다구매할게요 책은 예전에 구매했엇네요

1

jaenam

깃헙에 올려주시고 링크 공유해 주세요. 저도 돌려보고 말씀드릴게요.

0

nyamnyamgood



페이지는 /result/0/0 이고 모달버튼 누르면

ㄱ. 일부컴퍼넌트가 블러가안됨
ㄴ. pointer-events-none를 안하면 클릭이 안됩니다 ㅠ

클로드 초기 설정

0

2

1

사용자 스코프 설정 파일 적용 문제

0

5

1

클로드코드 유료플랜 할인 방법이 있을까요?

0

18

0

제네릭 클래스 핸드북 페이지가 undefined라고 나옵니다.

0

8

1

API Error : 400 에러의 원인과 해결방법이 궁금합니다!!

0

16

2

퍼미션 권한 설정 문의

0

18

2

Next.js + Tanstack Query BFF 구조 질문

0

12

1

커서에서 shift+enter가 안됩니다.

0

19

2

mcp 설치를 못하겠어요

0

33

2

라이브러리 관련 질문 있습니다!

0

24

2

output-styles은 Claude Code의 공식 기능이 아니라고 하는데 혹시 변경된걸까요?

0

23

2

클로드 변경

0

25

2

제네릭을 사용하실 때 콤마

0

167

2

popover createPortal 방식에서

0

147

2

스낵바를 만들 때 snackBarContext와 snackBarSetContext

0

146

2

snackbar를 createportal를 썻을 때 갯수 조절이 가능한가요?

0

193

1

useCallback, useMemo의 차이에 대해서 궁금합니다.

0

365

1

createPortal 활용해서 modal 만들 때 활용한 MutationObserver 코드 관련 질문

0

356

3

강의자료 (보일러플레이트) 다운로드 관련 질문

0

256

1

모달만드는 방식 질문

0

243

1

캐러셀 동작원리

0

306

2

dropdown 내부에서 data의 타입을 알아야 할까요?

0

199

1

Provider를 외부에 노출하는 것보다 내부 로직으로 숨기는 것은 어떤가요?

0

288

2

keyEventMap를 전역에 구현하신 이유가 궁금합니다!

0

272

2