테일윈드로 포탈로 모달작성시 뒤에 클릭이 안됩니다
<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;
Answer 2
1
modalRoot는
z-index를 확보하기 위해 html body의 가장 마지막에 위치시키는 것이 바람직합니다.
<body>
<ModalProvider />
{children}
<ModalRoot />
</body>modalRoot에는 스타일이 불필요합니다.
<div id="modalRoot" ref={ref} />
1
깃헙에 올려주시고 링크 공유해 주세요. 저도 돌려보고 말씀드릴게요.
팀& 서브 에이전트 실활용 방법은 어디에서 볼 수 있을까요?
0
5
1
선생님 강의토대로 개발중인데 질문이 하나있습니다 급함
0
11
2
To-Do App
0
5
0
MCP 서버 설치 내용이 실제와 달라 좀 헷갈립니다.
0
14
2
MCP가 토큰을 낭비한다고 뒷쪽에서 설명해주셨는데요.
0
13
2
[55강 질문] 로컬 커밋관련 질문
0
14
2
claude: command not found
0
14
2
git사용자 정보 설정 확인 관련
0
13
2
tdd-red 스킬에 허용 에러 범위에 대한 질문
0
14
2
claude code 실행시간
0
18
2
플랜모드에 대해 업데이트 내용이 있었던 것 같습니다!
0
14
2
서브에이전트 질문입니다.
0
17
2
제네릭을 사용하실 때 콤마
0
174
2
popover createPortal 방식에서
0
160
2
스낵바를 만들 때 snackBarContext와 snackBarSetContext
0
157
2
snackbar를 createportal를 썻을 때 갯수 조절이 가능한가요?
0
199
1
useCallback, useMemo의 차이에 대해서 궁금합니다.
0
377
1
createPortal 활용해서 modal 만들 때 활용한 MutationObserver 코드 관련 질문
0
365
3
강의자료 (보일러플레이트) 다운로드 관련 질문
0
264
1
모달만드는 방식 질문
0
249
1
캐러셀 동작원리
0
311
2
dropdown 내부에서 data의 타입을 알아야 할까요?
0
207
1
Provider를 외부에 노출하는 것보다 내부 로직으로 숨기는 것은 어떤가요?
0
293
2
keyEventMap를 전역에 구현하신 이유가 궁금합니다!
0
275
2

