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

home2 게시판 React 게시판 usestate 값 update 문제

usestate 값 update 문제

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

    오선화
    참가자
    안녕하세요
    프로젝트 하다가 문제가 생겨서 문의드립니다.
    
    const [productList, setProductList] = useState<INodeState[]>([])
    
    const onAddProduct = () => {
        setProductList((prev) => [
            ...prev,
            {
              id: newKey,
              state: (
                <ProductRow
                  key={newKey}
                  setValue={setProductValue}
                  onPrdDelete={() => onDeleteProduct(newKey)}
                />
              )
            }
          ])
    
    console.log(productList)
    }
    
    const onDeleteProduct = (prdkey: number) => {
    setProductList((prev) => prev.filter((obj) => obj.id !== prdkey))
    console.log(productList)
    }
    
    
    useEffect(() => {
        console.log(productList)
      }, [productList])
    
    
    ---------------------
    
    onAddProduct 에서 productList 추가시킨 걸 onDeleteProduct 에서 삭제하는 건데
    콘손로그로 찍어보면 useEffect안에서는 제대로 삽입되고 삭제되는데
    onAddProduct나 onDeleteProduct 에서는 하나가 덜 나옵니다. 화면에서도 하나가 덜 나와요.
    productList 처음 추가하면 useEffect 콘솔로그에서는 하나가 바로 나오는데 []으로 나오고
    두 개를 추가해야 하나가 삽입되는 식 한 번이 늦게 삽입됩니다.
    
    왜 바로 업데이트가 안되는 걸까요?
    화면에서도 바로 업데이트 되게 하려면 어떻게 해야할까요??
    
    
    
    
    
    
    #100827

    codingapple
    키 마스터
    컴포넌트를 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 호 / 개인정보관리자 : 박종흠