인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

인프런 커뮤니티 질문&답변

wjdwoals042님의 프로필 이미지

작성한 질문수

코드로 배우는 React 19 with 스프링부트 API서버

목록 처리

목록처리(2)에서 페이지 넘버 버튼을 누르면 표시되는 목록이 10개로 안 나옵니다

해결된 질문

작성

·

46

0

1.png.webp2.png.webp3.png.webp

 

위 사진들과 같이 각 페이지에 항목이 10개씩 표시되어야 하는데 페이지 버튼의 숫자대로 표시되고 있습니다.

ListConponent.js쪽이 이상한가 싶어서 찾아봐도 뭐가 문제인지 모르겠습니다.

혹시 참고 자료 필요하신 게 있으시다면 말씀 부탁드리겠습니다.

답변 3

0

wjdwoals042님의 프로필 이미지
wjdwoals042
질문자

1.png.webp2.png.webp3.png.webp

 

확인해보니 pageRequestDTO의size의 값이 page의 값과 일치하게 출력되네요. useCustomMove.js를 확인해 보니 아래와 같이 로직이 짜여져 있었습니다.

const size = getNum(queryParams.get('page'), 10)

get에서 size로 수정했더니 제대로 화면에 출력된 것을 확인했습니다. 감사합니다.

0

wjdwoals042님의 프로필 이미지
wjdwoals042
질문자

page, size 파라미터가 올바르게 전송되고 있는지 확인을 어떻게 하면 좋을까요?

구멍가게코딩단님의 프로필 이미지
구멍가게코딩단
지식공유자

브라우저의 개발자 도구를 보시면 Network 항목이 있습니다.

페이지 번호를 클릭할때 ?page=1&size=10과 같이 전송되는 것을 확인하실 수 있으실 겁니다.

 

아마도 제 생각에는 size 값이 잘못 전달되는거 같습니다.

0

인프런 AI 인턴님의 프로필 이미지

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

wjdwoals042님의 질문에 대해 유사한 문제를 다룬 사례들을 찾아보았습니다. 목록의 페이지 표시를 위한 컴포넌트가 리스트의 아이템 수를 제대로 조절하지 못할 때 주로 발생하는 문제는 상태 관리나 요청 시 전달되는 파라미터 설정에서 발생하는 경우가 많습니다.

다음은 관련 답변 링크와 설명입니다:

  1. 리스트 번호 클릭시 current가 항상 0입니다.

    • 해당 사례에서는 페이지 상태가 제대로 반영되지 않아 발생한 문제를 다루고 있습니다. current 값이 0으로 고정되던 문제를 해결하기 위해, 페이지 상태의 업데이트 로직을 점검하고 수정을 통해 해결하였습니다. 상태 관리 로직을 검토해 보는 것이 문제 해결의 첫걸음이 될 수 있습니다.
  2. 섹션3 목록처리(2) - 동일페이지 클릭 처리 부분에서 오류가 나서 문의드립니다.

    • 대개 데이터가 올바르게 불러와지지 않을 때 undefined 오류가 발생하며, 이 게시물에서는 데이터를 안전하게 가져오기 위한 방법을 다루고 있습니다. useEffect 등의 훅에서 비동기 데이터를 불러올 때, 값이 적절히 정의되었는지 확인하는 것이 중요합니다.
  3. 이동한 페이지 번호가 회색 색상으로 변하지 않습니다 ㅠ

    • 페이지 이동 시 시각적 효과가 올바르게 반영되지 않을 때와 관련한 사례입니다. CSS 클래스나 상태 변화가 적절히 처리가 이루어져야 합니다. 관련 코드를 점검하여 페이지 상태가 올바르게 변경되고 있는지 확인해보세요.

해당 문제는 목록에 표시될 항목 수를 제대로 조절하지 못하며 발생하기 때문에, serverData 혹은 데이터 요청 시 pagesize라는 파라미터가 올바르게 전송되고 있는지 추가 확인이 필요합니다. 데이터 요청 시 size에 10이 올바르게 설정되었는지 및 API에서 기대하는대로 동작하는지를 살펴보시면 좋겠습니다.

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