inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

[리뉴얼] React로 NodeBird SNS 만들기

saga 쪼개고 reducer와 연결하기

아바타 nickname

365

leehyunju

작성한 질문수 20

0

[useProfile.js]

import React, { useCallback } from "react";
import { Card, Avatar, Button } from "antd";
import Link from "next/link";
import { useDispatch, useSelector } from "react-redux";
import { logoutRequestAction } from "../reducers/user";

function UserProfile() {
  const dispatch = useDispatch();
  const { me, isLoggingOut, nickname } = useSelector((state=> state.user);

  const onLogOut = useCallback(() => {
    dispatch(logoutRequestAction());
  }, []);

  return (
    <>
      <Card
        actions={[
          <div key="twit">
            나의 작성 글<br />0
          </div>,
          <div key="followings">
            팔로잉
            <br />0
          </div>,
          <div key="follower">
            팔로워
            <br />0
          </div>,
        ]}
      >
        <Card.Meta
          avatar={<Avatar>{me.nickname[0]}</Avatar>}
          title={me.nickname}
        />
        <Link href="/login">
          <Button onClick={onLogOut} loading={isLoggingOut}>
            로그아웃
          </Button>
        </Link>
      </Card>
    </>
  );
}

export default UserProfile;

[reducers/user.js]

export const initialState = {
  isLoggingIn: false, // 로그인 시도중 => ture가 되면 로딩창을 띄운다.
  isLoggedIn: false,
  isLoggingOut: false, // 로그아웃 시도중 => ture가 되면 로딩창을 띄운다.
  me: null,
  signUpData: {},
  loginData: {},
};

export const loginRequestAction = (data=> {
  return {
    type: "LOG_IN_REQUEST",
    data,
  };
};

export const logoutRequestAction = () => {
  return {
    type: "LOG_OUT_REQUEST",
  };
};

const reducer = (state = initialState, action=> {
  switch (action.type) {
    case "LOG_IN_REQUEST":
      console.log("리듀서 로그인");
      return {
        ...state,
        isLoggingIn: true,
      };
    case "LOG_IN_SUCCESS":
      return {
        ...state,
        isLoggingIn: false,
        isLoggedIn: true,
        me: { ...action.data, nickname: "leehyunju" },
      };
    case "LOG_IN_FAILURE":
      return {
        ...state,
        isLoggingIn: false,
        isLoggedIn: false,
      };
    // --------------------------------------------
    case "LOG_OUT_REQUEST":
      return {
        ...state,
        isLoggingOut: true,
      };
    case "LOG_OUT_SUCCESS":
      return {
        ...state,
        isLoggingOut: false,
        isLoggedIn: false,
        me: null,
      };
    case "LOG_OUT_FAILURE":
      return {
        ...state,
        isLoggingOut: false,
      };
    default:
      return state;
  }
};

export default reducer;

TypeError: Cannot read property 'nickname' of null

안녕하세요 ! 제로초님 ! 아바타에서 닉네임 첫글자 따오는 부분이 계속 오류가 나서 직접 해결해 보려고 하였으나 도저히 안되서 질문드립니다. useSelector로 user 리듀서 끌고왔는데 nickname 부분만 데이터가 안불러와지는데 어떤게 문제일까요 .........😥

nodejs express redux react Next.js

답변 1

0

제로초(조현영)

me가 null인 겁니다. 잘 살펴보시면 me가 null인 경우가 있지 않나요? me?.nickname[0] 하시면 됩니다.

0

leehyunju

감사합니다!! 

넥스트 버젼 질문

0

75

2

로그인시 401 Unauthorized 오류가 뜹니다

0

88

1

무한 스크롤 중 스크롤 튐 현상

0

172

1

특정 페이지 접근을 막고 싶을 때

0

103

2

createGlobalStyle의 위치와 영향범위

0

93

2

인라인 스타일 리렌더링 관련

0

90

2

vsc 에서 npm init 설치시 오류

0

146

2

nextjs 15버전 사용 가능할까요?

0

157

1

화면 새로고침 문의

0

119

1

RTK에서 draft, state 차이가 있나요?

0

151

2

Next 14 사용해도 될까요?

0

452

1

next, node 버전 / 폴더 구조 질문 드립니다.

0

348

1

url 오류 질문있습니다

0

210

1

ssh xxxxx로 우분투에 들어가려니까 port 22: Connection timed out

0

372

1

sudo certbot --nginx 에러

0

1271

2

Minified React error 콘솔에러 (hydrate)

0

467

1

카카오 공유했을 때 이전에 작성했던 글이 나오는 버그

0

245

1

프론트서버 배포 후 EADDRINUSE에러 발생

0

325

1

npm run build 에러

0

517

1

front 서버 npm run build 중에 발생한 에러들

0

381

1

서버 실행하고 브라우저로 들어갔을때 404에러

0

335

2

css 서버사이드 랜더링이 적용되지 않아서 문의 드립니다.

0

283

1

팔로워 3명씩 불러오고 데이터 합쳐주는걸로 바꾸고 서버요청을 무한으로하고있습니다.

0

235

2

해시태그 검색에서 throttle에 관해 질문있습니다.

0

198

1