채용공고 올리기

마정한님을 응원해보세요!

이직/구직 중이에요

미리보기

기본 정보

이름
마정한
직업
프론트엔드 개발자
간단 소개

3년 차 Frountend 개발자로 React, Vue, Typescript를 위주로 SI, 스타트업, 300명 규모 회사까지 걸쳐서 기획/개발/배포/운영을 진행한 경험이 있습니다.

기술 스택

기술 스택

HTML/CSS, scss, JavaScript, React, Next.js, React Native, Vue.js, Vue 3, Nuxt.js, redux-toolkit, redux-saga, react-query, Vuex

자기소개

자기소개

사용자 중심의 제품 개발

  • 좋은 제품이란 깔끔하게 작성된 코드도 맞지만, 그것을 이용해 주는 사용자와 피드백과 개선의 선순환이 이루어지는 것이라고 생각합니다.
  • 언젠가는 나의 제품을 만들고 싶고 그것을 위해 사이드 프로젝트를 진행하고 있습니다.

꾸준한 기록과 학습

  • 저는 약 200개의 블로그 포스팅을 통해 꾸준히 기록하며 성장하고 있습니다.
  • 사내스터디와 외부스터디를 병행하여 함께 학습하기 위해 노력하고 있습니다.

문제 해결과 책임감

  • 주어진 개발 업무에 대해 어떤 환경이나 기술이라도 빠르게 해결하기 위해 최선을 다하고 있습니다.
  • 업무에 대한 책임감을 가지고 있어서 필요한 경우에는 근무시간 이외에도 자율적으로 학습합니다.

커뮤니케이션

  • 서비스 개발에 있어 기획, 디자인, 백엔드 등 다양한 사람들과 협업하기 위해서 소통이 필수라고 생각합니다.
  • 상대방이 이해하기 쉽도록 용어를 신중하게 선택하고 노력합니다.
  • 대화가 끝난 후에는 협업 도구를 활용하여 업무를 정리하여 효율적인 협업을 이끌어 내기 위해 노력합니다.

경력

회사명

이카운트

직급 | 부서 | 근무 유형

선임 | 개발본부

근무 기간

2023.03. ~ 2024.01. (11개월)

담당 업무

개발 생산성을 높이기 위해, VanillaJs로 작성된 Form,Grid 형태의 게시판을 React + TypeScript 마이그레이션

  1. Numeric Input 구현
  • 기능 : 사용자가 설정한 자릿수마다 설정한 특수문자를 삽입하고 최대 자릿수를 체크
  • 문제 : 해당 작업을 useEffect로 컴포넌트 자체에서 처리하다 보니 비즈니스 로직과 상태가 분리되지 못함
  • 해결 : useValidator, useDataFormatReverter, onDataFormatter 등 custom hook으로 비즈니스 로직 분리
  1. GridTreeComponent 구현
  • 기능 : 부모 요소와 자식 요소를 나누어서 렌더링하고, 부모 요소의 아이콘을 클릭하면 해당 그룹을 show/hide, 체크박스를 클릭하면 해당 그룹을 다 check/unCheck
  • 문제 : RowListData가 1차원 배열로 내려오면 어떻게 부모와 자식을 구분할 것인가
  • 해결 : Row 데이터 하나마다 부모 그룹을 설정하여 빈값이면 부모인 것이고, 아니라면 자식 요소라고 판단
  1. GridKeyboardActive 기능 구현
  • 기능 : Up, Down Key 입력 시 해당 Row의 Index를 찾아 Active 되며 해당 Element로 Scroll 이동
  • 문제 : Active 될 때 Row의 상태를 변경, 전체 리렌더링되는데 특정 Key를 계속 누를 시 성능 이슈 발생
  • 해결 : 컴포넌트의 props가 바뀌지 않았다면, 레렌더링을 방지하여 Row컴포넌트 성능 최적화
  1. Row 한 줄과 Row 안의 Cell 하나하나마다 BackgroundColor, FontColor, FontSize Style을 설정 조건부 서식 기능 개발

  2. onContextMenu 팝업 기능 개발

회사명

리스픽 - 회사 매각

직급 | 부서 | 근무 유형

팀원 | 개발팀

근무 기간

2022.07. ~ 2023.01. (7개월)

담당 업무

기존 PHP로 작성된 프로젝트 Nuxt.js 마이그레이션

  1. 튜터 프로필 페이지 Iframe 기능
  • 문제 : 고객분들이 항상 같은 질문을 하여 CS 부서의 업무가 증대
  • 해결 : 기획 단계에서 주도적으로 참여하여 자주 묻는 질문 답변 영상을 만들자고 건의
  • 성과 : CS 대응 30% 감소
  1. 튜터링 신청 페이지 임시저장 기능
  • 문제 : 해당 페이지 이탈 시, 작성 중이던 데이터가 날아가서 신청률이 저조해지는 문제
  • 해결 : 브라우저 저장소를 통하여 저장하여, 임시 저장된 데이터가 있다면 불러오거나 새로 작성할 것인지 선택
  • 성과 : 튜터링 신청률 120% 증가
  1. 크로스 브라우징 이슈 CORS
  • 문제 : 백엔드 쪽에서 허용 도메인을 설정하였으나, 계속하여 preflight 요청 발생하며 네트워크 통신이 되지 않음.
  • 해결 : 스프링 시큐리티 CORS 허용 정책 세팅하는 법이 따로 있어서 해당 부분을 백엔드 개발자분에게 전파
  • 성과 : 개발팀 커뮤니케이션 능력 증대
  1. 세션 기반 인증 체계를 토큰 기반 인증 체계(JWT)로 변경
  • 문제 : 세션 객체를 데이터 베이스에 저장하다보니 유저가 많아 질수록 부하가 걸릴 수 있다.
  • 해결 : 브라우저 저장소에 jwtToken을 저장해놓고 인터셉터에서 확인하여 존재한다면 로그인 처리, 존재하지 않는다면 로그인 페이지로 이동시킨다.
  • 성과 : 서버 부하 10% 감소 및 보안성 증대
회사명

아이엠폼

직급 | 부서 | 근무 유형

팀원 | 개발팀

근무 기간

2022.01. ~ 2022.04. (4개월)

담당 업무
  1. 불필요한 API 요청 제거 목적 미들웨어 Redux Saga 도입 제안
  • 문제 : 어떠한 요청을 하는 버튼을 빠르게 5번 클릭한다면 해당 요청을 5번 다 진행하는 문제
  • 해결 : redux-saga의 주요함수 takeLatest를 이용
  • 성과 : 기존에 진행 중이던 작업이 있다면 취소 처리하고 가장 마지막으로 실행된 작업만 수행하도록 변경.
  1. 웹 앱 기반 브라우저(Chrome, Safari)에서 트러블 슈팅 개선
  • 문제 : Input태그 type을 'number'로 설정하였으나, IOS 에서특수문자가 혼용된 키보드가 적용되는 현상
  • 해결 : Input태그에 attribute를 추가 inputmode="numeric" pattern="[0-9]*"
  • 성과 : 사용자 UX 개선
  1. media query사용하여 반응형 PC / Mobile 웹페이지 개발
회사명

아이온커뮤니케이션즈 - 프로젝트 중지

직급 | 부서 | 근무 유형

팀원 | 개발팀

근무 기간

2021.04. ~ 2021.10. (7개월)

담당 업무
  1. 메인 페이지 검색바에 상품 최근 검색어를 노출하는 기능 개발
  2. 검색어 순위 변동시 랭킹을 변경하는 기능 개발
  3. media query사용하여 반응형 PC / Mobile 웹페이지 개발
  4. 각종 UI/UX 작업

프로젝트

프로젝트명

aniwalk - 소셜 네트워크 서비스(SNS) 기반의 펫 산책 어플리케이션 - RN

소속/기관명

개인

프로젝트 기간

2022.11. ~ 진행 중

프로젝트 내용

사용기술

  • Typescript, ReactNative, StyleSheet

구성

  • 백엔드3, 프론트1 (본인 100%)

기능

  • Shorts Reels
  • FCM
  • apk 빌드
  • 소셜 로그인 (Kakao, Naver, Google)
  • Naver Map
  • 랜덤 닉네임 생성 및 인증
  • JWT token 인증
  • 캐루셀

문제

  • Apple 소셜 로그인 이메일 정보 비공개 시 처리 이슈 발생
  • 메인 페이지에서 Shorts 화면을 동영상으로 보여줄 시 성능 이슈 발생
  • 네이버 맵에서 지속적으로 사용자의 위치를 받아오다 앱을 내렸을 때 위치를 받아 오지 못하는 이슈

해결

  • 동일한 PhoneNumber의 경우 가입방지
  • 최초 렌더링 화면은 섬네일로 교체하고 클릭 시 영상 재생
  • 포어그라운드 이용하여 React-native AppState check
프로젝트명

쇼핑몰 클론 코딩 - ReactQuery, Graphql

소속/기관명

개인

프로젝트 기간

2022.06. ~ 2022.07.

프로젝트 내용

사용기술

  • ReactQuery, Graphql

구성

  • 개인

기능

  • ProductList
  • Product Detail
  • 제품 담기
  • cart 페이지에서 해당 제품과 개수 선택시 결제액 보여주기

도입계기

  • 기존에 ReactQuery를 사용하지 않으면, Product List API 값으로 리스트와 상세페이지를 보여주고 있는데 리스트와 상세페이지를 들어가고 나올 때마다 API를 요청함
  • 필요하지 않은 프로퍼티의 데이터도 받아서 불필요한 요청을 함.

학습내용

  • clientState와 ServerState의 상태 분리하여 상태관리
  • Stale time 관리로 불필요한 API 방지하는 법
  • OverFetching, UnderFetching 개념
프로젝트명

노션 이력서 Web 버전으로 구현 - PWA,Next

소속/기관명

개인

프로젝트 기간

2023.01. ~ 2023.02.

프로젝트 내용

사용기술

  • Next.js, PWA

구성

  • 개인

기능

  • 노션 이력서를 웹,데스크탑,모바일에서 볼 수 있음.

도입계기

  • 데스크톱 앱을 만들려면 일렉트론이라는 기술로 따로 만들어야 하는 불편함이 있어 웹, 모바일, 데스크톱까지 한 번에 개발할 수 있는 PWA로 개발

학습내용

  • 데스크톱 앱
  • 웹이기 때문에 심사를 거치지 않고, 빠른 코드 푸시 가능
  • 푸시알람 가능
  • 백그라운드 동기화

포트폴리오

URL

link

https://vite-react-query.vercel.app/

URL 링크
link

https://profile-htxdnqsrd-majunghan.vercel.app/

URL 링크

대외활동

활동명

사내 스터디

소속/기관명

이카운트

연도

내용

인원 : 프론트엔드 개발팀

  • 자바스크립트 (실행컨텍스트, 콜스텍, 호이스팅, this, 스코프체인, 클로저, 이벤트루프)
  • 문자인코딩 (아스키코드, 유니코드, base64, 문자열과 숫자형)
  • 네트워크 (계층, 프록시,HTTP, CORS)
  • 브라우저 렌더링 (파싱, 레이아웃, 페인트, 고속스크롤불가영역)
  • 리액트(리액트 직접만들기, 렌더링방식, 순수하게 유지하기, 리렌더링조건, hook, context와 전역상태관리자차이, useCallBack, useMemo, ref, useEffect, SyntheticEvent, Fiber)
활동명

외부 스터디

소속/기관명

개인

연도

내용

인원 : 2명
JavaScript Deep Dive 요약1

  • var와 let, const의 선언시 undefined 초기화 차이로 인한 호이스팅 상관관계
  • immutable과 mutable의 차이
  • 얇은복사와 깊은복사 차이
  • 스코프체인
  • 실행컨텍스트
  • 클로져
댓글