inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

12.9) 일기 관리 기능 구현하기 2

기존 mock data는 그룹이 따로 만들어지는데 뭔가 잘못된 건가요?

해결된 질문

94

green

작성한 질문수 11

0

image.png

이게 제 console인데요
아래 mock data는 자기들끼리 따로 그룹지어서 나오는데 선생님 콘솔에는 그냥 다 개별로 나오거든요...

뭐가 문제일까요?


import { useReducer, useRef } from "react";

const mockData = [
  {
    id: 1,
    createDate: new Date().getTime(),
    emotionId: 1,
    content: "1번 일기 내용",
  },
  {
    id: 2,
    createDate: new Date().getTime(),
    emotionId: 2,
    content: "2번 일기 내용",
  },
];

function reducer(state, action) {
  switch (action.type) {
    case "CREATE":
      return [action.data, ...state];
  }
}

function App() {
  const [data, dispatch] = useReducer(reducer, [mockData]);
  const idRef = useRef(3);

  const onCreate = (createDate, emotionId, content) => {
    dispatch({
      type: "CREATE",
      data: {
        id: idRef.current++,
        createDate,
        emotionId,
        content,
      },
    });
  };

  return (
    <>
      <button
        onClick={() => {
          onCreate(new Date().getTime(), 1, "Hello");
        }}>
        일기 추가 테스트
      </button>
    </>
  );
}

export default App;

제 코드도 첨부해봅니다,,,

 

javascript react node.js

답변 2

0

이정환 Winterlood

안녕하세요 이정환입니다.

useState로 data State 생성하는 부분이 강의와 코드가 다르네요

현재는 초기값을 [mockData] 라고 설정하고 계시지만, 아래 예제처럼 mockData 변수 자체를 넣어주셔야 합니다.

const [data, dispatch] = useReducer(reducer, mockData);

 

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다. green님.

상황을 살펴보니, useReducer의 초기 상태를 설정하는 부분에서 문제가 발생한 것 같습니다. useReducer의 초기 상태로 mockData를 배열로 한번 더 감싸서 주어야 하는데, 현재 코드를 보면 불필요하게 중첩된 배열로 초기 상태를 선언하셨습니다. 이로 인해 mockData가 하나의 그룹으로 묶여 출력되고 있습니다.

여기서 사용하신 useReducer의 초기 상태 부분을 다음처럼 수정해 보세요:

const [data, dispatch] = useReducer(reducer, mockData);

이렇게 수정하시면 mockDatadata 배열 안에 개별적으로 들어가게 되어, 각 항목이 개별적으로 표시될 것입니다.

관련하여 데이터 저장 및 불러오기와 관련된 이슈를 다룬 질문들이 있습니다. 다음 질문 링크가 도움이 될 수 있습니다: 데이터추가하기에서 못넘어가고 있어요….ㅡㅡ

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

useEffect와 lifecycle문의

0

16

1

프론트엔드 학습 수준 문의

0

27

2

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

0

42

2

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

0

51

2

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

0

76

2

이후의 커리큘럼 문의

0

101

2

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

0

49

2

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

0

82

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