inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[리뉴얼] 맛집 지도앱 만들기 (React Native & NestJS)

useAuth

217

gga01075

작성한 질문수 21

0

22:41 타임을 보시면
src/hooks/queries/useAuth.ts파일에서 리액트 쿼리를 이용하여 선언한 것을 useAuth라는 함수로 만들어서 반환해주고 있는데요

function useAuth() {
  const signupMutation = useSignup();
  const refreshTokenQuery = useGetRefreshToken();
  const getProfileQuery = useGetProfile({
    enabled: refreshTokenQuery.isSuccess, // true일떄 쿼리가 실행
  });
  const isLogin = refreshTokenQuery.isSuccess;
  const loginMutation = useLogin();

  return {
    signupMutation,
    refreshTokenQuery,
    getProfileQuery,
    isLogin,
    loginMutation,
  };
}

src/navigations/root/RootNavigator.tsx 파일에서 위의 함수를 호출할때

 const isLogin = useAuth();

로 반환받고있습니다. 구조분해할당이 아니라 객체 그 자체로 받는 이유가 있을까요?

react-native typescript nestjs react-query zustand

답변 2

1

Kyo

영상보시면 조금뒤에 바로 수정합니다! {isLogin} 이 맞습니다.

0

인프런 AI 인턴

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

질문 주신 부분은 useAuth라는 커스텀 훅에서 반환하는 객체를 RootNavigator에서 어떻게 받아야 할지에 대한 사항입니다. 일반적으로 커스텀 훅에서 여러 값이나 함수를 반환할 때, 구조 분해 할당(destructuring assignment)을 통해 필요한 값만 골라서 사용할 수 있습니다. 하지만 질문에서 언급하신 것처럼 전체 객체를 받으신 경우는 초기 개발 단계에서 디버깅을 쉽게 하기위해, 또는 특정 이유로 객체를 한꺼번에 관리하고 사용하기 쉽도록 하려는 의도가 있을 수 있습니다.

구조분해할당을 사용하면 코드가 더 깔끔하고, 사용하고 싶은 값만 선택적으로 불러올 수 있어서 유지보수가 편리합니다. 예를 들어, useAuth에서 반환하는 객체를 사용할 때, 필요한 값만 선택하여 사용할 수 있습니다.

RootNavigator.tsx에서 useAuth()를 호출하여 반환값을 구조 분해 하여 받도록 바꾸는 방법은 아래와 같습니다:

const { isLogin, loginMutation, signupMutation, refreshTokenQuery, getProfileQuery } = useAuth();

이렇게 사용하면 각 변수에 바로 접근할 수 있어 가독성이 높아지는 장점이 있습니다.

관련된 유사한 질문이나 해결 방법을 참고하시려면 다음 링크를 확인해보세요:

이 링크에서는 리액트의 훅과 관련된 다양한 사례들을 다루고 있으니, 사용 방식에 대한 참고가 되실 것입니다.

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

react-native-screens 버전 호환 문제

2

153

1

안드로이드 실행 중 Drawer네비게이션과 MapView 성능 문제

0

103

2

해당 강의 부분은 실제 활용하기에 부족해 제가 해결한 방법입니다.

0

96

1

소스코드가 강의 순서랑 다른가요?

0

72

2

현재 Windows에서 VsCode로 작업 중인데 추후에 IOS도 가능하게 하려면

0

115

2

react-native-fast-image는 react 19 버전에서 설치가 안되나요?

0

209

2

SQL Shell의 역할이 무엇인가요?

0

91

1

혹시 해당 강의에서invalidateQueries를 사용한 이유가 있을까요?

0

79

2

빠르게 실행해보고싶습니다.

0

82

1

강의 수강 순서 관련

0

70

1

애뮬레이터 실행 방법

0

99

2

무료 Apple ID로 실기기 테스트 가능한가요?

0

90

2

ios 실기기 연결

0

70

2

npm run ios에러

0

74

1

10월 삭제 예정인 강의는 이유를 알 수 있을까요?

0

101

1

캘린더 개발 후에 navigation 에 대해서 궁금한 점이 있습니다.

0

51

1

안드로이드 위치 권한 이슈 2가지 문의

0

71

1

지도가 보이려면 음.. 작성해주신 스타일과 다르게

0

74

0

제대로 설치한거같은데 안드로이드랑 ios 둘다 앱실행이 안되는것같아요

0

83

3

강의 내용을 보면 전체적으로 function 함수 키워드를 사용하시는데

0

69

2

강의 3-9 에서 useGetRefreshToken 훅 안에 즉시 함수로 처리하는 이유가 궁금합니다!

0

82

2

사내에서 figma.com 업로드 안되나요?

0

96

1

AWS EC2 + RDS 설정

0

85

2

안드로이드 안켜집니다.

0

91

2