inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

부트캠프에서 알려주지 않는 것들 (리액트 렌더링 최적화 편) 2편

Virtualized List 구현해보기 (1)

Virtualized List 에 관한 질문이 있습니다.

해결된 질문

512

공부하자

작성한 질문수 2

3

Virtualized List 강의를 보고 궁금증이 생겼습니다.

 

이 최적화 방식이 레이지 로드 라고 불리는 웹 최적화 기술인 것 같은데, 인터섹션 옵저버를 바닐라 코드로 구현한 방식이라고 이해하면 될까요? 만일 같은 방식이라면 인터섹션 옵저버를 사용하지 않은 이유가 있나요? 제가 깊이가 부족해서 도움을 얻고자 질문 남겨봐요!!

(이게 들었던 해당 강의로 질문이 가는건지 모르겠네요 뭐가 뭔지..)

 

react 기술면접

답변 1

1

애프터캠프

좋은 질문이네요

제가 react-window 코드를 보고 그 아이디어로 구현을 해본 것인데요. 올려주신 질문을 보니까 IntersectionObserver API로 구현이 가능할 것 같네요. react-window를 구현한 개발자가 IntersectionObserver를 모르진 않았을 것 같은데...

제가 한번 구현해보고 장단점을 답글로 남기겠습니다

 

(해당 강의로 질문이 잘 도착했습니다 😀)

1

공부하자

답변 주셔서 감사합니다!!

1

애프터캠프

IntersectionObserver 로 구현을 해봤습니다. (리포지토리 intersection-observer 에서 확인 가능합니다)

https://github.com/things-not-learn-from-bootcamp/virtualized-list/tree/intersection-observer

 

우선 최초에 렌더링 할 때 일부만 렌더링 되도록 구현했고 보이지 않을 때 DOM에서 해제하는 것은 구현하지 못했습니다.

말씀하신대로 IntersectionObserver 로도 구현이 가능해보이고 제가 강의에서 구현한 내용은 항상 itemSize를 넘겨줘야 해서 고정된 높이의 아이템들만 렌더링이 가능했는데 IntersectionObserver을 잘 활용하면 유동적인 높이의 아이템도 구현이 가능하겠군요!

2

공부하자

와.. 정말 감사합니다! 바쁘신 와중에도 잊지 않고 답변해주시다니.. 올려주신 코드 보면서 학습에 큰 도움 받고 있습니다. 고맙습니다~~

실무에서 진행한 쿼리 개선 사례 공유 관련 질문드립니다

0

5

1

power shell에서는 claude가 정상 실행되는데, cursor terminal에서는 실행 에러 발생하네요.

0

7

1

live server, korean도 확장팩 검색이 되지 않습니다.

0

9

0

CLAUDE.local.md

0

10

1

55강 관련 질문(커밋이 완료되지 않을 때)

0

9

1

클로드 코드를 쓸때 Cursor IDE의 이점?

0

15

1

오류사항

0

27

3

md 파일을 위한 폴더 관리의 기준이 궁금합니다.

0

15

2

혹시 결제연동

0

22

1

claude code가 작업중일때 ctrl t 눌러서 진행상황 확인 불가

0

23

1

메타프롬프트 관련

0

25

2

side bar positon. 어떻게 해도 안돼요..;

0

20

1

모델 고정방법 문의

0

21

2

98강. 1인 사이드프로젝트 시 질문

0

31

2

state 객체로 묶기

0

18

0

강의화면과 Cursor프로그램 화면이 달라서요..

0

25

2

커서 설치했는데 이해 안되네요

0

32

2

공식사이트 관련과 workspace

0

21

2

수업 잘 들었습니다.

2

24

2

user-memory-setup 저장 관련

0

22

2

user-memory-setup 작성하고 클로드 코드로 돌아가는 방법

0

20

2

Automatic batching에 관해 궁금한 점이 있습니다.

0

105

1

쓰레드 관련

1

425

1

useTransition 질문입니다!

1

405

2