inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

리액트 리렌더링 안되게 하는법

310

dong1hyun

작성한 질문수 2

0

문제가 발생한 코드 로직에 대해 설명드리자면 유저가 어떤 상태 선택창을 띄우고 상태를 변경하면 서버로 요청을 보내고 응답이 와서 변경된 데이터로 새로 렌더링 되는 로직입니다. 그런데 여기서 저는 상태 선택창을 닫히지 않게 하고 싶습니다. 그런데 useState를 사용하면 리렌더링 됐을 때 당연히 상태가 초기화 돼서 선택창이 사라질 것이기 때문에 useRef를 사용했습니다.

아래가 그 코드인데 useRef로 했음에도 리렌더링 되고 초기 상태인 false로 바뀌어버립니다. 그래서 상태창을 유지하지 못하고 있습니다. 해결법 좀 아시는 고수님들 도움 좀 주셨으면 좋겠습니다 ㅠ

const maintainStatus = useRef(false);

const changeStatus = (status: LocationStatusType) => {
        mutate({
            locationStatus: status
        }, {
            onSuccess: async (res) => { // 성공시
                await queryClient.invalidateQueries({ queryKey: homelessListQueryKey }); // 쿼리 최신화
                maintainStatus.current = true;
                console.log("maintainStatus.current:", maintainStatus.current) //true 출력
            }
        })
    }
    useEffect(() => {
        console.log("Updated maintainStatus.current:", maintainStatus.current); // false 출력
    }, [maintainStatus.current]);

react react-query useRef

답변 1

0

김민규

선택창이라는게 새 창을 말씀하시는건가요?
+ react-query를 사용중이시고 mutate 요청 후 쿼리 캐시를 만료시키고있다면 리렌더링되는것은 당연합니다

0

dong1hyun

맞습니다. 근데 리렌더링 됐을 때 상태가 초기화 된다고 잘못 생각했네요. 결국 해결했는데 원인은 부모의 키 설정과 관련한 문제였습니다. 키가 변경되면서 리렌더링이 아니라 아예 언마운트 되면서 상태가 초기화 되는 것이였습니다.

.md 파일명 대소문자 구분 문의

0

2

0

/output-style 이 안뜹니다

0

7

2

프로젝트 초기화 문제

0

2

1

섹션8,9부터는 진짜 못따라가겠어요...ㅠㅠ

0

7

1

파워쉘에서 이미지 복붙이 안됩니다.

0

8

1

160 강의 ppt-maker에 대해

0

12

1

이벤트 관리 앱 프로젝트 개발 순서

0

8

0

supabase next.js와 mcp

0

8

0

스테이징 10000개

0

9

1

160. Claude Code로 PPT 만들기 관련 질문

0

11

1

task master 관련질문입니다.

0

13

1

android crud중 c 영상이 12초만 있는 잘린 영상이에요.

0

17

2

터미널 시작폴더가 달라요

0

27

2

my-profile-site 404 error

0

19

2

노션 .env.local

0

26

1

shrimp_data - WebGUI.md

0

21

2

powershell 복붙 문제

0

26

2

디렉토리가 보이지 않아요.

0

26

1

쉬림프 설치

0

20

2

회원가입 구현 (구현 후 최종 화면 출력 X)

0

21

2

tsakmaster api키

0

25

1

terminal-setup을 해도 shift+Enter 키로 줄바꿈이 되지 않아요.

0

24

2

ll- al 명령어 관련 문의

0

31

1

cursor ui 변경 문의

0

31

1