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

home2 게시판 React 게시판 TypeError: state.dispatch is not a function 에러

TypeError: state.dispatch is not a function 에러

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

    쭈꾸미
    참가자

     

    --cart.js

    <tbody>
                        {state.map((data,idx) =>(
                            <tr key={idx}>
                                <td>{data.id}</td>
                                <td>{data.name}</td>
                                <td><button onClick={()=>{ state.dispatch({type:'수량증가', id:data.id})}}>+</button> 1 <button>-</button></td>
                                <td>{data.price}</td>
                            </tr>
                        ))}
     </tbody>
     

     

    -- index.js

    function reducer(state = init, action){

      let copy = [...state]; //deep copy

      if(action.type === '수량증가'){
        let d = copy.find( a => a.id === action.id);
        d.quan++;
        return copy
      }else if(action.type === '수량감소'){
        let d = copy.find( a => a.id === action.id);
        d.quan--;
        return copy
      }else{ //기본값 리턴
        return copy
      } 
    }

    let store = createStore(reducer);

     

     

    TypeError: state.dispatch is not a function 에러가 뜨는데 원인을 도무지 모르겠습니다 ㅠㅠ

     

    #14523

    쭈꾸미
    참가자

     

     //

    #14526

    쭈꾸미
    참가자

    function func(state){ //state를 props화 하기
        return {
           state : state
        }
    }

    export default connect(func)(Cart)

     

    connect도 잘 연결해두었습니다..

    #14528

    쭈꾸미
    참가자

    악! 해결했습니다 

     

    컴포넌트에 props를 비구조화 할당 해준게 문제였네요..ㅠ

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

About

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

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

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