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

home2 게시판 React 게시판 useState 질문있습니다.

useState 질문있습니다.

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

    김초연
    참가자

    안녕하세요.

    지금 part 2. 마지막 강의에 주문하기 버튼 누르면 재고 개수가 감소하도록 만드는  코드 작성하고 있는데, 제 생각처럼 기능하지 않아서 질문 남깁니다.

     

    `

    <button
                className='btn btn-danger'
                onClick={() => {
                  const newStock = [...props.stock];
                  props.handleStock(newStock[id] -=1);
                }}>
                주문하기
              </button>

    `

    혹은, 

    `

    <button
                className='btn btn-danger'
                onClick={() => {
                  const newStock = [...props.stock];
                  props.handleStock(newStock[id] -1);
                }}>
                주문하기
              </button>

    `

    이렇게 작성했었는데, 아래와 같은 에러가 뜨면서 작동하지 않습니다. 

     

    그래서 아래와 같이 수정해보니 정상적으로 작동하였습니다.

    `

    <button
                className='btn btn-danger'
                onClick={() => {
                  const newStock = [...props.stock];
                  newStock[id] -= 1;
                  props.handleStock(newStock);
                }}>
                주문하기
              </button>

    `

    저는 두 개의 코드가 다를 게 없다고 생각이 드는데, 왜 state변경 함수 안에 newStock 배열의 값을 변경해 주려고 하면 안되는 걸까요?? 

     

    #29227

    codingapple
    키 마스터

    newStock[id] -1

    이런건 array에서 id번자료 꺼내서 -1 해서 그자리에 남겨주세요 라는 뜻이라 그렇습니다

    state변경함수엔 state통째로 넣어야합니다 

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

About

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

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

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