inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

saga 이펙트 알아보기

saga 비동기 처리에서 페이지 이동

308

okky

작성한 질문수 20

0

saga에서 비동기 통신으로 성공 또는 실패로 나뉘는데

try_catch에서 통신이 성공하면

어디에서 페이지를 이동하는 코드를 작성해야 하나요?

 

1. component

dispatch({
     type: UPLOAD_REQUEST

     data: index

})

// Router.push("/upload")

 

2. saga

function* addItem(action) {

  try {

    const result =  yield call(api)

    yield put({       

      type: UPLOAD_SUCCESS

      data: result.data

    }) 

// Router.push("/upload")

  } catch (err) {

    yield put({

      type: UPLOAD_FAUILRE

      error : err.response.data

    })

  }  

}

 

API 통신에 경고문(alert) 창도

성공 또는 실패에 따라 유동적으로 달고 싶은데

조건을 어떻게 주고 어느 파일에 다는지 궁금합니다.

express react redux nodejs Next.js

답변 1

0

제로초(조현영)

정해진 건 없고 한 군데로 통일하면 됩니다. 다만 리덕스 툴킷을 사용하지 않으면 컴포넌트에서 성공/실패 후처리를 하는 게 조금 어렵습니다. 보통 거기서 라우터 전환이나 얼럴트를 하거든요.

0

okky

페이지를 넘길 때 컴포넌트 안에서만 Router.push 되더라고요 

밖에 saga, reducer 먹지 않아서 

구글링 해보니 store 안에 history 연결을 해서 페이지를 이동하더라구요

 

 그래서 제가 한 방식은

const router = uesRouter( );

 

const onClickEvnet = useCallback(( ) => {

  const history = router;

  dispatch({
     type: UPLOAD_REQUEST,

     history,

   })

})

 

history 넘어온 객체를 통해서 saga에서 history.push("/")를 하면 되더라구요

근데 이렇게 하면 단점은 페이지를 이동할 경우에 계속 history를 넣어줘야 한다는 단점이 있어요,

넥스트 버젼 질문

0

91

2

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

0

104

1

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

0

199

1

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

0

117

2

createGlobalStyle의 위치와 영향범위

0

104

2

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

0

99

2

vsc 에서 npm init 설치시 오류

0

159

2

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

0

166

1

화면 새로고침 문의

0

129

1

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

0

164

2

Next 14 사용해도 될까요?

0

455

1

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

0

359

1

url 오류 질문있습니다

0

218

1

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

0

394

1

sudo certbot --nginx 에러

0

1298

2

Minified React error 콘솔에러 (hydrate)

0

482

1

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

0

257

1

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

0

341

1

npm run build 에러

0

526

1

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

0

399

1

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

0

351

2

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

0

291

1

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

0

252

2

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

0

207

1