inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

한 입 크기로 잘라 먹는 리액트(React.js) : 기초부터 실전까지

12.8) 일기 관리 기능 구현하기 1

copyList

해결된 질문

324

정준영

작성한 질문수 1

1

안녕하세요 강의 듣는 중 궁금한점이 생겨서 질문을 드리게 됩니다.

영상 24:32 부분에서 const copyList = JSON.parse(JSON.stringify(diaryList));

으로 하셧는데 원본 배열을 정렬을 하게되어 불변성 문제 때문에 Json.stringify 로 문자열로 바꿧다가 다시 JSON.parse로 새로운 배열을 만들어 값을 받았는데

혹시 그럼 스프레드 연산자인 const copyList = [...diaryList] 이렇게 하게 된다면 위 코드와 다르게 동작이 될까요..?

javascript nodejs react

답변 1

8

이정환 Winterlood

안녕하세요 정준영님

강사 이정환입니다.



스프레드 연산자를 이용해도 깊은 복사를 구현하여 불변성을 지킬 수 있습니다.

다만 이는 1차원 배열 or 객체에만 해당됩니다.

따라서 다차원 (객체 속에 또 객체 or 배열 속에 객체)의 비 원시 자료형값을 깊게 복사하기 위해서는

스프레드 연산자가 아닌 JSON 메서드를 이용하여 깊은 복사를 수행해야 합니다.

또는 lodash라는 좋은 라이브러리가 있습니다.

이 lodash라이브러리의 deepClone API를 이용하면 더 성능좋고 간결하게 깊은 복사를 구현하실 수 있으니 참고 해 보시면 도움이 될 것 같습니다 😄

0

정준영

감사합니당

useEffect와 lifecycle문의

0

20

2

프론트엔드 학습 수준 문의

0

28

2

리액트 챕터별 코드에서 eslint 설정파일이 없어요

0

43

2

데이터 로딩중 화면만 계속 나와요!!

0

51

2

퍼블리셔일경우 어느정도 수준까지 강의를 들어야할까요

0

76

2

이후의 커리큘럼 문의

0

101

2

실슬환경 설정에서 save후 console.log 부분이 새로고침이 안되는현상입니다.

0

49

2

최적화 관련 질문있습니다 (useMemo 등)

0

83

3

프로바이더 컴포넌트의 위치는 어떤 기준인가요?

1

79

3

Date 객체에 관련하여 질문드립니다.

0

82

2

리액트 개정판 교재 질문

0

58

2

예제코드가 안나와요!

0

75

2

select a variant 선택에서 javascript와 javascript+react compiler 중 무엇을 선택해야하나요? com

0

104

2

onMouseEnter 관련 문의 드립니다

0

89

3

배열의 렌더링 관련 질문 드립니다.

0

70

2

2:40초 refObj를 콘솔로 출력시 오류가 발생합니다.

0

111

2

TS, 리액트 강의중에 뭘 먼저 수강하는게 좋을까요?

0

131

2

useCallback 적용한 onCreate, onUpdate, onDelete 함수..

0

66

1

vs code 자동완성관련 문의

0

107

2

91강 useEffect내에서 상태변화함수 호출시 발생하는 에러

1

174

2

87강 필터 함수 질문

0

65

2

useRef, useState count 비교

0

64

2

안된다고했던 이유가 무엇이었는지 모르겠습니다

0

86

2

85강에서 객체를 왜 클래스로 만들어서 new 하지 않는건지 궁금합니다.

0

73

2