Today I Learned
- 2주차 기술 멘토링 노트 작성
- 마이페이지 닉네임, 프로필 사진 변경 기능 구현
2주차 기술 멘토링 노트 작성 링크
https://teamsparta.notion.site/2-b2224420ad11483c9b795df9e278c153
Next.js 구동 순서
Next의 구동순서는 _app.js와 _document.js가 제일 처음 실행되며, 두 파일 모두 pages 폴더 안에 있어야 한다.
1. _app.js
- 최초로 실행되는 파일로, Client에서 띄어지는 전체 컴포넌트의 레이아웃.
- 공통 레이아웃으로 최초에 실행되어 내부에 들어갈 컴포넌트들을 실행한다.
2. _document.js
- 그다음에 _document.js가 실행되는데, 이는 _app.js에서 구성한 HTML이 어떤 형태로 들어갈지 구성해 주는 것.
출처 https://kjhg478.tistory.com/25
Next.js에서 로그인 여부에 따라 페이지 접근 차단하기 (middleware)
아직 기능 구현은 안 했지만 참고하기 좋은 링크들을 기록해 둔다!
https://nextjs.org/docs/advanced-features/middleware
https://velog.io/@sbinha/@sbinha/next.js-에서-middleware.ts의-역할과-최근-활용-예시
https://velog.io/@sssssssssy/NextJs-URL-직접-접근-막기#server코드
React Query 윈도우 focus 시 refetch 설정 변경하기
// Disabling Globally
const queryClient = new QueryClient({
defaultOptions: {
queries: {
refetchOnWindowFocus: false, // default: true
},
},
})
function App() {
return <QueryClientProvider client={queryClient}>...</QueryClientProvider>
}
- If a user leaves your application and returns and the query data is stale, TanStack Query automatically requests fresh data for you in the background. You can disable this globally or per-query using the refetchOnWindowFocus option:
페이지에 focus가 갈 때마다 쿼리를 계속해서 불러오는 게 불필요한 부분 같아서 refetchOnWindowFocus 설정을 false로 변경했다.
참고
https://velog.io/@blackeichi/react-query-focus시-refetch방지하기
https://psychomildang.tistory.com/67
https://tanstack.com/query/v4/docs/react/guides/window-focus-refetching
특정 조건에서만 쿼리 실행하기
// Users 데이터 불러오기
const { data: users, isLoading }: any = useQuery('users', getUsersList, {
enabled: !!session, // session이 ture인 경우에만 useQuery를 실행함
});
유저의 데이터가 들어오고 난 다음에 useQuery를 실행하고 싶어서 enabled 속성을 추가했다.
Lazy Queries
The enabled option can not only be used to permanently disable a query, but also to enable / disable it at a later time. A good example would be a filter form where you only want to fire off the first request once the user has entered a filter value:
function Todos() {
const [filter, setFilter] = React.useState('')
const { data } = useQuery({
queryKey: ['todos', filter],
queryFn: () => fetchTodos(filter),
// ⬇️ disabled as long as the filter is empty
enabled: !!filter
})
return (
<div>
// 🚀 applying the filter will enable and execute the query
<FiltersForm onApply={setFilter} />
{data && <TodosTable data={data}} />
</div>
)
}
참고
https://velog.io/@haleyjun/useQueries-종속쿼리-조건-만족-후-쿼리-실행시키기
https://tanstack.com/query/v4/docs/react/guides/disabling-queries
회고
오늘도 끝나지 않는 undefined 지옥 경험... 결국엔 해결했지만 너무 코드가 지저분해진 거 같다.