• 로그인
  • 장바구니에 상품이 없습니다.

home2 게시판 React 게시판 가격순 정렬할 떄, 깊은 복사 질문입니다.

가격순 정렬할 떄, 깊은 복사 질문입니다.

3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 글쓴이
  • #25120

    강성구
    참가자

       <button
                onClick={() => {
                  let list = shoes.sort((a, b) => a.price - b.price);
                  setShoes([...list]);
                  // state의 값을 다시 재정비해줘야함. 그 역할 setShoes
                  // 유레카 이걸 안해서 바로바로 버튼을 눌러도 적용이 안됐었음
                }}
              >
                가격순 정렬하기!!
              </button>

     

    위의 코드에서 

    setShoes([...list]) 를 해줘야 정상작동을 하더라구요.

    ...은 깊은 복사를 해서 메로리 주소까지 독립적으로 만들어주고 기존의 값과는 별개다. 

    라는 이론적인 학습은 했지만 왜 해줘야하는지 명확히 잡히질 않아서 질문올립니다.

    #25126

    codingapple
    키 마스터

    리액트에서 state 변경사항을 확인할 때

    기존 state == 신규 state

    등호로 비교합니다 

    근데 state가 array, object 자료일 경우

    깊은복사 안하고 대충복사해서 내부 값만 변경해봤자 == 로 비교하면 기존 state == 신규 state 똑같다고 나옵니다 

    그래서 state 안바뀌었다고 생각합니다 

    #25147

    강성구
    참가자

    감사합니다

    명확히이해됐습니다

3 글 보임 - 1 에서 3 까지 (총 3 중에서)
  • 답변은 로그인 후 가능합니다.

About

현재 월 700명 신규수강중입니다.

  (09:00~20:00) 빠른 상담은 카톡 플러스친구 코딩애플 (링크)
  admin@codingapple.com
  이용약관, 개인정보처리방침
ⓒ Codingapple, 강의 예제, 영상 복제 금지
top

© Codingapple, All rights reserved. 슈퍼로켓 에듀케이션 / 서울특별시 강동구 고덕로 19길 30 / 사업자등록번호 : 212-26-14752 온라인 교육학원업 / 통신판매업신고번호 : 제 2017-서울강동-0002 호 / 개인정보관리자 : 박종흠