inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

Slack 클론 코딩[실시간 채팅 with React]

모달 만들기

typesciprt error

166

Senn

작성한 질문수 1

0

현 강의를 시청하는 중 "layout/workspace" 의 useSWR를 사용할때 제너릭을  <IUser | false> 로 지정해 준 후 기존에 적혀있는 userData에서 아래와 같은 타입에러가 나기 시작했습니다.

Property 'email' does not exist on type 'false | IUser'. Property 'email' does not exist on type 'false'.

 

깃헙 코드와 비교해보았지만 다른점은 없었고, 어떤부분이 문제가되어 이러한 오류가 발생하는 걸까요?

해당 오류 때문에 제너릭을 지우고 아래 Workspaces.map((ws) => ...) 부분의 ws : IWorkspace 로 타입지정을 해주면 이상없이 동작하기는 합니다.

구글링을 해보아도 현재버전 타입스크립트 이슈가 따로 있지는 않은것 같고, 어디 실수한 부분이 있을까요?

 

import { IUser } from '../../DataTypes';
const { data: userData, mutate } = useSWR<IUser | false>('http://localhost:3095/api/users', fetcher);

//..//
<span onClick={onClickUserProfile}>
<ProfileImg src={gravatar.url(userData.email, { s: '28px', d: 'retro' })} alt={userData.nickname} />
{showUserMenu && (
<Menu style={{ right: 0, top: 38 }} show={showUserMenu} onCloseModal={onClickUserProfile}>
<img src={gravatar.url(userData.email, { s: '28px', d: 'retro' })} alt={userData.nickname} />
<div>
<span id={'profile-name'}>{userData.nickname}</span>
<span id={'profile-active'}>Active</span>
</div>
<LogOutButton onClick={onLogout}>Logout</LogOutButton>
</Menu>
)}
</span>
{userData?.Workspaces.map((ws) => {
return (
<Link key={ws.id} to={`/workspaces/${123}/channel/일반`}>
<WorkspaceButton>{ws.name.slice(0, 1).toUpperCase()}</WorkspaceButton>
</Link>
);
})}

클론코딩 react Socket.io babel typescript 웹팩

답변 1

0

제로초(조현영)

전체 코드를 다 올려주세요. 원인은 User가 false가 될 수 있는 가능성 때문입니다. 따라서 user가 false일 때를 제외하면 에러가 발생하지 않습니다.

기본 셋팅과 관련하여

0

106

1

초기 셋팅 back과 front만 남겨두고 다 지운 후 진행 방법

0

109

2

focus 시에만 화면 업데이트 되는 이유 + 해결방법

0

164

2

useEffect 개수 관리

0

122

2

라이브러리 서치 방법

0

118

2

함수 정의 패턴

0

80

1

npm run dev 에러

0

156

3

npx webpack 후 에러

0

187

2

'void' 형식 식의 truthiness를 테스트할 수 없습니다.ts(1345)

0

151

2

사용자 가입시 에러발생 (TypeError: Cannot read properties of null (reading 'addMembers')

1

190

2

초기세팅중 packge.json 에러떠요

0

162

2

CORS - Access-Control-Allow-Origin 누락 문제

0

439

3

로그인 페이지 무한 새로고침 현상

0

608

2

Module not found: Error: Can't resolve './App' 에러

0

969

1

배포 방법

0

306

2

npm run dev 시 빌드가 매우 느려졌습니다

0

1010

2

alias 경로 설정 오류

0

460

2

fetcher 함수의 data 값이 두번 찍히는 이유

0

282

1

제네릭 질문

0

225

2

ts-node 대신 tsx 사용여부

0

377

1

배포 관련 질문

0

249

1

[nginx + https] 서비스를 실행하면 niginx가 아닌 서비스 화면을 보여주게 하고 싶습니다.

0

394

2

[배포하기] webpack에 aws 퍼블릭 IPv4 주소 와 포트 주소를 작성하고 나서 빌드후 실행하면 오류가 발생합니다.

0

341

1

users 호출 시 쿠키가 담기지 않는 이슈 질문드립니다.

0

252

2