강의

멘토링

로드맵

Inflearn brand logo image

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

ddobbi님의 프로필 이미지
ddobbi

작성한 질문수

한 입 크기로 잘라먹는 Next.js(v15)

4.1) 앱 라우터의 데이터 페칭

서버 컴포넌트 console.log

해결된 질문

작성

·

128

·

수정됨

-1

앱 라우터의 데이터 패칭 수업 중

 

서버 컴포넌트에서 찍은 콘솔창은

브라우저에서는 보이지 않는다고 하시는데

 

브라우저 콘솔에 아주 잘보이거든여?

 

제가 잘 못 이해한걸 까요?

 

// 랜덤으로 추천도서 가져옴
async function RecoBooks() {
  //api로 데이터를 불러오면 타입스크립트는 어떤 결과값을 가져올지 몰라 타입정보를 지정해줘야한다.
  const response = await fetch(
    `${process.env.NEXT_PUBLIC_API_SERVER_URL}/book/random`
  );
  //예외처리 필수
  if (!response.ok) {
    return <div>오류가 발생했습니다...</div>;
  }

  const recoBooks: BookData[] = await response.json(); //타입 : BookData[]

  console.log("랜덤 => ", recoBooks);

  //정상적으로 불러와서 렌더링까지 확인할 수 있다.
  return (
    <div>
      {recoBooks.map((book) => (
        <BookItem key={book.id} {...book} />
      ))}
    </div>
  );
}

export default function Home() {
  //async 제외
  // 인덱스 페이지

  return (
    <div className={style.container}>
      {/* section 태그는 div 태그와 이름만 다른뿐 기능은 같다 */}
      <section>
        <h3>지금 추천하는 도서</h3>
        {/*books은 mock폴더안에 임시 배열데이터, list 형태로 렌더링 */}
        <RecoBooks />
      </section>

      <section>
        <h3>등록된 모든 도서</h3>
        <AllBook />
      </section>
    </div>
  );
}
image

답변 1

1

이정환 Winterlood님의 프로필 이미지
이정환 Winterlood
지식공유자

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

올려주신 콘솔 메세지 앞에 "Server" 라는 태그가 보이실텐데요, 이는 Next.js 서버와 브라우저가 개발 과정에서의 디버깅을 용이하도록 돕기 위해 서버측의 콘솔을 브라우저에서도 보이도록 제공하는 기능입니다. 따라서 해당 코드가 실제로 브라우저에서 실행된 것은 아니며 프로덕션 환경에서는 출력되지 않습니다.

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

감사합니다!

 

ddobbi님의 프로필 이미지
ddobbi

작성한 질문수

질문하기