본문 바로가기
반응형
[React] API 응답 시간이 너무 길다면 어떻게 해야 할까? 만약 API 응답 시간이 너무 오래 걸린다면 어떻게 처리해야 할까? 사용자가 버튼을 클릭 했는데 아무 반응이 없거나, 무한 로딩만 표시되고 있다면 아마 몇 초도 안돼서 이탈할 것 같다. 이 글에서 React를 사용한 여러 예시를 통해 어떤 방법이 더 좋을지 알아보자. AbortController로 요청 중단하기 응답 시간이 너무 오래 걸리면 웹 요청을 중단하는 것은 어떨까? "불러오는 중"과 같은 로딩 화면만 보여주는 것이 아닌 시간을 제한하여 사용자를 마냥 기다리게 하지 않고, 이렇게 함으로써 네트워크 트래픽도 줄일 수 있다. AbortController는 Fetch API와 같은 웹 요청을 중단 할 수 있게 만들어준다. AbortController() 생성자를 통해 객체를 생성한 다음, 해당 객체의 .. 2023. 11. 4.
너디너리 데모데이 후기 올해 12월은 내가 회사를 다닌 지 2년이 되는 달이다. 이제 곧 3년 차가 되는데, 인사이트를 얻고자 오랜만에 IT 관련 행사를 다녀왔다. 대부분의 컨퍼런스 발표들이 그렇듯, 유튜브에 영상이 업로드 되겠지만 막상 올라오면 잘 안보게 되는 것도 있고 시간을 정하여 온전히 발표에만 집중하고 싶었다. 뤼튼 PO님과의 대화 내가 신청한 발표 세션은 후반 세션이었기 때문에 점심 먹고 여유롭게 갔는데도 시간이 남았었다. 1층에는 IT 기업 부스들이 쭉 늘어나 있었다. 초반에는 긴장을 해서 그런지 관심있는 곳보다는 적극적인 곳에 먼저 가게 되더라. 조금씩 긴장이 풀리고, 기업 부스들을 구경하다 뤼튼이라는 곳에 들렀다. 지금은 ChatGPT를 유료로 사용하고 있지만 뤼튼은 출시 초기에 무료에다가, 이미지 생성까지 해.. 2023. 9. 10.
회사 웹 서비스 개선기: URL 인코딩 최근 문제를 재미있게 해결한 경험이 있다. 그렇게 큰 문제는 아니었지만, 나름 뿌듯했던 순간들이 있어서 글을 쓰게 되었다. 이번 글에서는 해당 문제의 해결 과정과 URL 인코딩에 대한 간략한 설명을 다룬다. 해시(#) 이후 문자들이 잘려요 회사에서는 이미지 파일들을 업로드 하고 관리하기 위한 회사 전용 웹 서비스가 있다. 예를 들어, 행사나 새로운 서비스를 홍보하는 이미지를 업로드하면 회사 홈페이지나 어드민 페이지의 공지사항 모달창에 표시된다. 업로드를 할 때는 이미지의 노출 기간과 링크를 입력할 수 있다. 문제는 이미지 링크에 해시(#) 문자를 포함하면 '#'부터 이후 문자들까지 전부 잘려서 업로드가 된다는 것이었다. 이미지를 클릭하면 링크 페이지로 이동 후, 해당 위치로 스크롤이 되지 않는 것이다. .. 2023. 8. 15.
프로젝트 진행 중 내가 한 후회들 회사에서 프로젝트를 하다보면 이런저런 후회들을 하게된다. 이 글은 그 후회들을 공유하며, 나아가 내가 겪은 것들을 회고하고 개선하고자 하는 내용을 담았다. 올해 3월에 시작한 이번 프로젝트는 나에게 의미가 크다. 그 과정에서 내가 한 (약간은 바보 같은) 후회들을 여러분과 공유하려 한다. 그리고 이를 통해 내가 겪었던 것들을 간접적으로 경험하여, 조금이라도 도움이 될 수 있기를 바란다. 1. 기획서를 꼼꼼하게 읽지 않았다 2년 차 개발자이고 여러 프로젝트를 해왔지만, 사실 이번 프로젝트 때 기획서를 처음 받아보았다. 그리고 나는 그 당시에 기획서를 볼 일이 거의 없을 거라 생각했다. 디자이너님이 디테일한 내용은 피그마에 댓글로 남겨 주시기도 했고, '막힐 때마다 기획서를 보면 충분히 구현이 가능할 것 같.. 2023. 8. 6.
React 페이지네이션 UI 직접 만들기 페이지네이션(pagination)은 큰 데이터를 사용자가 보기 편하도록 작은 부분으로 나누어 여러 페이지로 표시하는 것을 뜻한다. 사용자는 이 페이지들을 순차적으로 또는 선택적으로 볼 수 있다. 요즘은 비즈니스나 UX적인 측면에서 무한 스크롤이 더 많이 쓰이는 것 같지만, 사용자가 특정 정보를 찾기 위해 몇 페이지를 건너뛰어야 하거나, 어드민의 데이터 테이블 UI와 같이 내용이 많고 구조화된 정보를 제공해야 하는 경우에는 페이지네이션이 더 적합할 수 있다. 페이지네이션 핵심 로직 이해하기 페이지네이션의 일반적인 예를 들자면, 사용자는 페이지마다 보여지는 데이터의 양을 선택할 수 있고, 원하는 페이지 번호를 클릭함으로써 해당 페이지로 즉시 이동할 수 있다. 또한, 앞뒤 페이지로 쉽게 이동할 수 있는 네비게.. 2023. 8. 2.
React에서 Swiper Element 사용 시 TypeScript 에러 해결하기 스와이퍼 리액트 페이지에 들어가보면 가장 먼저 눈에 띄는 문구가 있다. Swiper React components will likely to be removed in future versions. It is recommended to migrate to Swiper Element instead. If you are upgrading from Swiper 8 to Swiper 9, check out Migration Guide to Swiper 9 If you are looking for v8 docs, they are here v8.swiperjs.com 스와이퍼 리액트 컴포넌트는 향후 버전에서 제거될 가능성이 있으니, 웹 컴포넌트로 만든 스와이퍼 엘리먼트로 마이그레이션하라는 것이다. 빨간색 배경에다가 .. 2023. 6. 18.
2년 차 프론트엔드 개발자 상반기 회고 요즘 일이 많아져서 정말 바쁘다. 개발팀 내 부장님, 대리님과 소통하는 것은 물론, 디자인팀과 기획팀과도 더 자주 소통하며 바쁘게 다니고 있다. 개발자로 취업하기 전에 들었던 얘기 중에 프론트엔드 개발자는 '중간 다리' 역할을 잘 해야 한다는, 즉 양쪽 모두와 원활하게 소통해야 한다는 것이 생각난다. 업무에 대한 압박감 의사소통엔 큰 어려움을 느끼지 않았다. 그런데 문제는 서비스 출시 마감일이 너무 빨라서 어려움을 겪고 있다. 이렇게 큰 프로젝트를 처음부터 만드는 일이, 특히 2년 미만의 경력으로 프론트엔드 개발을 모두 소화하기엔 너무 벅찬 일정인 것 같다. 얼마나 압박감이 심했냐하면, 프로젝트 생각만해도 식은땀이 나고 괜히 몸에 열이 올라왔다. 머리까지 아파와서 같이 식사하는 동료들에게 이야기해보니, .. 2023. 6. 5.
반응형