간편결제, 신용카드 청구할인
카카오페이 3,000원
(카카오페이 결제 시 최대할인 3천원 / 5만원 이상 결제, 기간 중 1회)
PAYCO(페이코) 최대 5,000원 할인
(페이코 신규 회원 및 90일 휴면 회원 한정)
북피니언 롯데카드 30% (26,460원)
(최대할인 3만원 / 3만원 이상 결제)
EBS 롯데카드 20% (30,240원)
(최대할인 3만원 / 3만원 이상 결제)
인터파크 NEW 우리V카드 10% (34,020원)
(최대할인 3만원 / 3만원 이상 결제)
인터파크 현대카드 7% (35,160원)
(최대할인 3만원 / 3만원 이상 결제)
Close

리액트를 다루는 기술 : 입문부터 대규모 애플리케이션까지 한 권으로![개정판]

소득공제

2013년 9월 9일 이후 누적수치입니다.

판매지수 3,604
?
판매지수란?
사이트의 판매량에 기반하여 판매량 추이를 반영한 인터파크 도서에서의 독립적인 판매 지수입니다. 현재 가장 잘 팔리는 상품에 가중치를 두었기 때문에 실제 누적 판매량과는 다소 차이가 있을 수 있습니다. 판매량 외에도 다양한 가중치로 구성되어 최근의 이슈도서 확인시 유용할 수 있습니다. 해당 지수는 매일 갱신됩니다.
Close
공유하기
  • 저 : 김민준
  • 출판사 : 길벗
  • 발행 : 2019년 08월 31일
  • 쪽수 : 908
  • 제품구성 : 전1권
  • ISBN : 9791160508796
정가

42,000원

  • 37,800 (10%할인)

    2,100P (5%적립)

  • 구매

    29,400 (30%할인)

    1,470P (5%적립)

할인혜택
적립혜택
  • I-Point 적립은 출고완료 후 14일 이내 마이페이지에서 적립받기한 경우만 적립됩니다.
  • 추가혜택
    배송정보
    주문수량
    감소 증가
    • 북카트 담기
    • 바로구매
    • 매장픽업
    • 이벤트/기획전

    • 연관도서(1)

    • 사은품(3)

    책소개

    리액트 베스트셀러 1위, 본문과 소스 전면 업그레이드!
    기본기를 꼼꼼하게! 실전에서 효과적으로 활용하는 방법까지 알차게 배우자!


    [리액트를 다루는 기술] 개정판이 나왔습니다. 리액트 16.8 버전에 Hooks라는 기능이 도입되면서 함수형 컴포넌트에서도 상태 관리를 할 수 있게 되었습니다. 이에 맞춰 책에 사용된 주요 예시를 모두 함수형 컴포넌트 형태로 전환했습니다. 기존 내용을 보강 및 개선하고, 초판에 다루지 않았던 새로운 내용도 많이 수록했습니다. 리액트의 빅 팬이자 현업 프로그래머로서 리액트를 꾸준히 활용해 온 저자의 명쾌한 설명과 노하우가 더욱 알차게 담긴 개정판입니다.
    또한, 리액트를 공부할 때 알아야 할 자바스크립트 기초 및 ES6 문법을 다룬 링크(벨로퍼트와 함께하는 모던 자바스크립트)와 책에서 사용한 리액트 라이브러리와 관련 도구의 버전이 업그레이드되면 필요한 변경 사항을 공지하는 링크(저자 깃허브)도 제공합니다.

    출판사 서평

    리액트, 현장 밀착 입문서는 따로 있다!

    자바스크립트의 기본 기능과 문법을 숙지한다

    리액트의 기본기를 익히려면 자바스크립트는 필수! 잘 모르는 자바스크립트 문법이 나오면 반드시 체크하자. 리액트 개발에 필요한 ES6 문법은 적재적소에 배치했다.

    원리를 알면 더 효율적으로 사용할 수 있다
    동작 원리를 이해하면 리액트를 왜 사용해야 하는지, 어떻게 사용하면 좋은지 큰 그림을 그릴 수 있다. 작은 프로젝트를 해보면서 리액트를 통해 개발자 경험을 향상시키는 방법을 배우자.

    웹 애플리케이션에 리액트를 적용해본다.
    리액트를 적용해보면서 실전 감각을 익힌다. UI 업데이트 과정을 간결하게, 복잡한 애플리케이션 개발도 컴포넌트 기반으로 쉽게, 자바스크립트 개발을 손쉽게.

    리액트를 이해하기 위한 핵심 개념은 물론이고 어떤 상황에서 어떻게 사용해야 하는지, 왜 이렇게 사용하는 것이 효과적인지, 공식 문서에는 나오지 않는 실전 노하우와 팁을 풍부하게 담았다.
    또한, 프로젝트 생성부터 코드를 작성 및 개선하고, 배포하기까지 실무에 바로 응용할 수 있도록 예제를 준비했다. 먼저 일정 관리 애플리케이션을 만들면서 리액트의 기본기를 다지고, 다음으로 여러 실습 예제를 진행하면서 컴포넌트 스타일링, 상태 관리, API 연동, 라우팅, 코드 스플리팅, 서버사이드 렌더링 등 리액트를 활용한 다양한 기술을 사용해본다. 마지막으로 프런트엔드 프로젝트를 통해 배운 지식을 종합적으로 활용해본다.

    추천사

    리액트의 이론과 원리를 쉽게 이해하고, 근래에 추가된 새로운 기술을 포함하여 세련된 코드를 작성할 수 있습니다. 단순히 리액트만이 아니라 리덕스나 Node.js의 Koa를 비롯하여 코드 스플리팅, 비동기 로딩, SSR 등과 같은 고급 주제까지 다룹니다.
    - 손경환 / 삼성SDS JS 개발자

    이 책의 가장 큰 장점은 배운 지식을 응용하여 프로젝트를 만들어 보는 부분입니다. 정말 많은 도움을 받았습니다.
    - 홍종완 / 우아한형제들 개발자

    새로 나온 React Hooks, Context API 등 리액트의 최신 내용을 담고 있습니다. 이론과 실습을 병행하면서 점차 코드를 개선해 나가는 방식이라 이해하기 쉬웠습니다.
    - 성중원 / 프런트엔드 개발자

    이 책에서 좋았던 점은 리액트 핵심 내용인 리덕스와 리덕스 미들웨어에 대한 설명이 잘 나와 있는 점과 리액트, Node.js, Koa, MongoDB 기술 스택으로 하나의 완성된 프로젝트를 따라 해 보고 경험해 볼 수 있는 점, 유용한 도구 및 라이브러리에 대한 소개와 깨알 팁이었습니다. 여기에 리액트의 최신 내용까지 반영된 알짜배기 책입니다.
    - 허성룡 / 프런트엔드 개발자

    리액트를 정확한 이해 없이 수박 겉핥기식으로 사용하고 있다는 느낌을 받는다면 이 책을 추천합니다. 'Why?'에 집중한 설명, 웹 개발 전반을 알려주는 단계별 실습, 또한 다양한 미들웨어나 서버 사이드 렌더링, 배포와 테스트 부분에서 리액트에 대한 기본기를 쌓을 수 있습니다.
    - 박정이 / 개발자

    리액트에 대한 기본 지식이 없는 상태에서도 쉽게 이해할 수 있도록 꼼꼼하게 설명되어 있습니다. 또한, 실제 실무에서 어떻게 사용되는지 상세히 알려줍니다.
    - 김범준 / 라프텔(연세대학교) 개발자

    리액트뿐만 아니라 다양한 라이브러리를 필요한 곳에 같이 사용하여 쉽게 배울 수 있었습니다.
    - 정지훈 / IOS 앱 개발

    실무에서 약간 응용하여 사용할 수 있는 좋은 예제가 많다. 참고하지 않은 부분이 없을 정도로 내용이 매우 실무적이다.
    - 조용진 / 스타트업 모두의 캠퍼스 개발자

    문법적인 설명뿐만 아니라 사용하는 개념과 왜 그 개념이 도입될 수밖에 없는지를 이해하는 것이 중요하다고 생각합니다. 이 책은 그 점이 좋았습니다.
    - 신형진 / 연세대학교 대학원생

    목차

    1장 리액트 시작
    1.1 왜 리액트인가?
    -1.1.1 리액트 이해
    1.2 리액트의 특징
    -1.2.1 Virtual DOM
    -1.2.2 기타 특징
    1.3 작업 환경 설정
    -1.3.1 Node.js와 npm
    -1.3.2 yarn
    -1.3.3 에디터 설치
    -1.3.4 Git 설치
    -1.3.5 create-react-app으로 프로젝트 생성하기

    2장 JSX
    2.1 코드 이해하기
    2.2 JSX란?
    2.3 JSX의 장점
    -2.3.1 보기 쉽고 익숙하다
    -2.3.2 더욱 높은 활용도
    2.4 JSX 문법
    -2.4.1 감싸인 요소
    -2.4.2 자바스크립트 표현
    -2.4.3 If 문 대신 조건부 연산자
    -2.4.4 AND 연산자(&&)를 사용한 조건부 렌더링
    -2.4.5 undefined를 렌더링하지 않기
    -2.4.6 인라인 스타일링
    -2.4.7 class 대신 className
    -2.4.8 꼭 닫아야 하는 태그
    -2.4.9 주석
    2.5 ESLint와 Prettier 적용하기
    -2.5.1 ESLint
    -2.5.2 Prettier
    2.6 정리

    3장 컴포넌트
    3.1 클래스형 컴포넌트
    3.2 첫 컴포넌트 생성
    -3.2.1 src 디렉터리에 MyComponent.js 파일 생성
    -3.2.2 코드 작성하기
    -3.2.3 모듈 내보내기 및 불러오기
    3.3 props
    -3.3.1 JSX 내부에서 props 렌더링
    -3.3.2 컴포넌트를 사용할 때 props 값 지정하기
    -3.3.3 props 기본값 설정: defaultProps
    -3.3.4 태그 사이의 내용을 보여 주는 children
    -3.3.5 비구조화 할당 문법을 통해 props 내부 값 추출하기
    -3.3.6 propTypes를 통한 props 검증
    -3.3.7 클래스형 컴포넌트에서 props 사용하기
    3.4 state
    -3.4.1 클래스형 컴포넌트의 state
    -3.4.2 함수형 컴포넌트에서 useState 사용하기
    3.5 state를 사용할 때 주의 사항
    3.6 정리

    4장 이벤트 핸들링
    4.1 리액트의 이벤트 시스템
    -4.1.1 이벤트를 사용할 때 주의 사항
    -4.1.2 이벤트 종류
    4.2 예제로 이벤트 핸들링 익히기
    -4.2.1 컴포넌트 생성 및 불러오기
    -4.2.2 onChange 이벤트 핸들링하기
    -4.2.3 임의 메서드 만들기
    -4.2.4 input 여러 개 다루기
    -4.2.5 onKeyPress 이벤트 핸들링
    4.3 함수형 컴포넌트로 구현해 보기
    4.4 정리

    5장 ref: DOM에 이름 달기
    5.1 ref는 어떤 상황에서 사용해야 할까?
    -5.1.1 예제 컴포넌트 생성
    -5.1.2 App 컴포넌트에서 예제 컴포넌트 렌더링
    -5.1.3 DOM을 꼭 사용해야 하는 상황
    5.2 ref 사용
    -5.2.1 콜백 함수를 통한 ref 설정
    -5.2.2 createRef를 통한 ref 설정
    -5.2.3 적용
    5.3 컴포넌트에 ref 달기
    -5.3.1 사용법
    -5.3.2 컴포넌트 초기 설정
    -5.3.3 컴포넌트에 메서드 생성
    -5.3.4 컴포넌트에 ref 달고 내부 메서드 사용
    5.4 정리

    6장 컴포넌트 반복
    6.1 자바스크립트 배열의 map() 함수
    -6.1.1 문법
    -6.1.2 예제
    6.2 데이터 배열을 컴포넌트 배열로 변환하기
    -6.2.1 컴포넌트 수정하기
    -6.2.2 App 컴포넌트에서 예제 컴포넌트 렌더링
    6.3 key
    -6.3.1 key 설정
    6.4 응용
    -6.4.1 초기 상태 설정하기
    -6.4.2 데이터 추가 기능 구현하기
    -6.4.3 데이터 제거 기능 구현하기
    6.5 정리

    7장 컴포넌트의 라이프사이클 메서드
    7.1 라이프사이클 메서드의 이해
    7.2 라이프사이클 메서드 살펴보기
    -7.2.1 render( ) 함수
    -7.2.2 constructor 메서드
    -7.2.3 getDerivedStateFromProps 메서드
    -7.2.4 componentDidMount 메서드
    -7.2.5 shouldComponentUpdate 메서드
    -7.2.6 getSnapshotBeforeUpdate 메서드
    -7.2.7 componentDidUpdate 메서드
    -7.2.8 componentWillUnmount 메서드
    -7.2.9 componentDidCatch 메서드
    7.3 라이프사이클 메서드 사용하기
    -7.3.1 예제 컴포넌트 생성
    -7.3.2 App 컴포넌트에서 예제 컴포넌트 사용
    -7.3.3 에러 잡아내기
    7.4 정리

    8장 Hooks
    8.1 useState
    -8.1.1 useState를 여러 번 사용하기
    8.2 useEffect
    -8.2.1 마운트될 때만 실행하고 싶을 때
    -8.2.2 특정 값이 업데이트될 때만 실행하고 싶을 때
    -8.2.3 뒷정리하기
    8.3 useReducer
    -8.3.1 카운터 구현하기
    -8.3.2 인풋 상태 관리하기
    8.4 useMemo
    8.5 useCallback
    8.6 useRef
    -8.6.1 로컬 변수 사용하기
    8.7 커스텀 Hooks 만들기
    8.8 다른 Hooks
    8.9 정리

    9장 컴포넌트 스타일링
    9.1 가장 흔한 방식, 일반 CSS
    -9.1.1 이름 짓는 규칙
    -9.1.2 CSS Selector
    9.2 Sass 사용하기
    -9.2.1 utils 함수 분리하기
    -9.2.2 sass-loader 설정 커스터마이징하기
    -9.2.3 node_modules에서 라이브러리 불러오기
    9.3 CSS Module
    -9.3.1 classnames
    -9.3.2 Sass와 함께 사용하기
    -9.3.3 CSS Module이 아닌 파일에서 CSS Module 사용하기
    9.4 styled-components
    -9.4.1 Tagged 템플릿 리터럴
    -9.4.2 스타일링된 엘리먼트 만들기
    -9.4.3 스타일에서 props 조회하기
    -9.4.4 props에 따른 조건부 스타일링
    -9.4.5 반응형 디자인
    9.5 정리

    10장 일정 관리 웹 애플리케이션 만들기
    10.1 프로젝트 준비하기
    -10.1.1 프로젝트 생성 및 필요한 라이브러리 설치
    -10.1.2 Prettier 설정
    -10.1.3 index.css 수정
    -10.1.4 App 컴포넌트 초기화
    10.2 UI 구성하기
    -10.2.1 TodoTemplate 만들기
    -10.2.2 TodoInsert 만들기
    -10.2.3 TodoListItem과 TodoList 만들기
    10.3 기능 구현하기
    -10.3.1 App에서 todos 상태 사용하기
    -10.3.2 항목 추가 기능 구현하기
    -10.3.3 지우기 기능 구현하기
    -10.3.4 수정 기능
    10.4 정리

    11장 컴포넌트 성능 최적화
    11.1 많은 데이터 렌더링하기
    11.2 크롬 개발자 도구를 통한 성능 모니터링
    11.3 느려지는 원인 분석
    11.4 React.memo를 사용하여 컴포넌트 성능 최적화
    11.5 onToggle, onRemove 함수가 바뀌지 않게 하기
    -11.5.1 useState의 함수형 업데이트
    -11.5.2 useReducer 사용하기
    11.6 불변성의 중요성
    11.7 TodoList 컴포넌트 최적화하기
    11.8 react-virtualized를 사용한 렌더링 최적화
    -11.8.1 최적화 준비
    -11.8.2 TodoList 수정
    -11.8.3 TodoListItem 수정
    11.9 정리

    12장 immer를 사용하여 더 쉽게 불변성 유지하기
    12.1 immer를 설치하고 사용법 알아보기
    -12.1.1 프로젝트 준비
    -12.1.2 immer를 사용하지 않고 불변성 유지
    -12.1.3 immer 사용법
    -12.1.4 App 컴포넌트에 immer 적용하기
    -12.1.5 useState의 함수형 업데이트와 immer 함께 쓰기
    12.2 정리

    13장 리액트 라우터로 SPA 개발하기
    13.1 SPA란?
    -13.1.1 SPA의 단점
    13.2 프로젝트 준비 및 기본적인 사용법
    -13.2.1 프로젝트 생성 및 라이브러리 설치
    -13.2.2 프로젝트에 라우터 적용
    -13.2.3 페이지 만들기
    -13.2.4 Route 컴포넌트로 특정 주소에 컴포넌트 연결
    -13.2.5 Link 컴포넌트를 사용하여 다른 주소로 이동하기
    13.3 Route 하나에 여러 개의 path 설정하기
    13.4 URL 파라미터와 쿼리
    -13.4.1 URL 파라미터
    -13.4.2 URL 쿼리
    13.5 서브 라우트
    13.6 리액트 라우터 부가 기능
    -13.6.1 history
    -13.6.2 withRouter
    -13.6.3 Switch
    -13.6.4 NavLink
    13.7 정리

    14장 외부 API를 연동하여 뉴스 뷰어 만들기
    14.1 비동기 작업의 이해
    -14.1.1 콜백 함수
    -14.1.2 Promise
    -14.1.3 async/await
    14.2 axios로 API 호출해서 데이터 받아 오기
    14.3 newsapi API 키 발급받기
    14.4 뉴스 뷰어 UI 만들기
    -14.4.1 NewsItem 만들기
    -14.4.2 NewsList 만들기
    14.5 데이터 연동하기
    14.6 카테고리 기능 구현하기
    -14.6.1 카테고리 선택 UI 만들기
    -14.6.2 API를 호출할 때 카테고리 지정하기
    14.7 리액트 라우터 적용하기
    -14.7.1 리액트 라우터의 설치 및 적용
    -14.7.2 NewsPage 생성
    -14.7.3 Categories에서 NavLink 사용하기
    14.8 usePromise 커스텀 Hook 만들기
    14.9 정리

    15장 Context API
    15.1 Context API를 사용한 전역 상태 관리 흐름 이해하기
    15.2 Context API 사용법 익히기
    -15.2.1 새 Context 만들기
    -15.2.2 Consumer 사용하기
    -15.2.3 Provider
    15.3 동적 Context 사용하기
    -15.3.1 Context 파일 수정하기
    -15.3.2 새로워진 Context를 프로젝트에 반영하기
    -15.3.3 색상 선택 컴포넌트 만들기
    15.4 Consumer 대신 Hook 또는 static contextType 사용하기
    -15.4.1 useContext Hook 사용하기
    -15.4.2 static contextType 사용하기
    15.5 정리

    16장 리덕스 라이브러리 이해하기
    16.1 개념 미리 정리하기
    -16.1.1 액션
    -16.1.2 액션 생성 함수
    -16.1.3 리듀서
    -16.1.4 스토어
    -16.1.5 디스패치
    -16.1.6 구독
    16.2 리액트 없이 쓰는 리덕스
    -16.2.1 Parcel로 프로젝트 만들기
    -16.2.2 간단한 UI 구성하기
    -16.2.3 DOM 레퍼런스 만들기
    -16.2.4 액션 타입과 액션 생성 함수 정의
    -16.2.5 초깃값 설정
    -16.2.6 리듀서 함수 정의
    -16.2.7 스토어 만들기
    -16.2.8 render 함수 만들기
    -16.2.9 구독하기
    -16.2.10 액션 발생시키기
    16.3 리덕스의 세 가지 규칙
    -16.3.1 단일 스토어
    -16.3.2 읽기 전용 상태
    -16.3.3 리듀서는 순수한 함수
    16.4 정리

    17장 리덕스를 사용하여 리액트 애플리케이션 상태 관리하기
    17.1 작업 환경 설정
    17.2 UI 준비하기
    -17.2.1 카운터 컴포넌트 만들기
    -17.2.2 할 일 목록 컴포넌트 만들기
    17.3 리덕스 관련 코드 작성하기
    -17.3.1 counter 모듈 작성하기
    -17.3.2 todos 모듈 만들기
    -17.3.3 루트 리듀서 만들기
    17.4 리액트 애플리케이션에 리덕스 적용하기
    -17.4.1 스토어 만들기
    -17.4.2 Provider 컴포넌트를 사용하여 프로젝트에 리덕스 적용하기
    -17.4.3 Redux DevTools의 설치 및 적용
    17.5 컨테이너 컴포넌트 만들기
    -17.5.1 CounterContainer 만들기
    -17.5.2 TodosContainer 만들기
    17.6 리덕스 더 편하게 사용하기
    -17.6.1 redux-actions
    -17.6.2 immer
    17.7 Hooks를 사용하여 컨테이너 컴포넌트 만들기
    -17.7.1 useSelector로 상태 조회하기
    -17.7.2 useDispatch를 사용하여 액션 디스패치하기
    -17.7.3 useStore를 사용하여 리덕스 스토어 사용하기
    -17.7.4 TodosContainer를 Hooks로 전환하기
    -17.7.5 useActions 유틸 Hook을 만들어서 사용하기
    -17.7.6 connect 함수와의 주요 차이점
    17.8 정리

    18장 리덕스 미들웨어를 통한 비동기 작업 관리
    18.1 작업 환경 준비
    18.2 미들웨어란?
    -18.2.1 미들웨어 만들기
    -18.2.2 redux-logger 사용하기
    18.3 비동기 작업을 처리하는 미들웨어 사용
    -18.3.1 redux-thunk
    -18.3.2 redux-saga
    18.4 정리

    19장 코드 스플리팅
    19.1 자바스크립트 함수 비동기 로딩
    19.2 React.lazy와 Suspense를 통한 컴포넌트 코드 스플리팅
    -19.2.1 state를 사용한 코드 스플리팅
    -19.2.2 React.lazy와 Suspense 사용하기
    -19.2.3 Loadable Components를 통한 코드 스플리팅
    19.3 정리

    20장 서버 사이드 렌더링
    20.1 서버 사이드 렌더링의 이해
    -20.1.1 서버 사이드 렌더링의 장점
    -20.1.2 서버 사이드 렌더링의 단점
    -20.1.3 서버 사이드 렌더링과 코드 스플리팅 충돌
    20.2 프로젝트 준비하기
    -20.2.1 컴포넌트 만들기
    -20.2.2 페이지 컴포넌트 만들기
    20.3 서버 사이드 렌더링 구현하기
    -20.3.1 서버 사이드 렌더링용 엔트리 만들기
    -20.3.2 서버 사이드 렌더링 전용 웹팩 환경 설정 작성하기
    -20.3.3 빌드 스크립트 작성하기
    -20.3.4 서버 코드 작성하기
    -20.3.5 정적 파일 제공하기
    20.4 데이터 로딩
    -20.4.1 redux-thunk 코드 준비하기
    -20.4.2 Users, UsersContainer 컴포넌트 준비하기
    -20.4.3 PreloadContext 만들기
    -20.4.4 서버에서 리덕스 설정 및 PreloadContext 사용하기
    -20.4.5 스크립트로 스토어 초기 상태 주입하기
    -20.4.6 redux-saga 코드 준비하기
    -20.4.7 User, UserContainer 컴포넌트 준비하기
    -20.4.8 redux-saga를 위한 서버 사이드 렌더링 작업
    -20.4.9 usePreloader Hook 만들어서 사용하기
    20.5 서버 사이드 렌더링과 코드 스플리팅
    -20.5.1 라우트 컴포넌트 스플리팅하기
    -20.5.2 웹팩과 babel 플러그인 적용
    -20.5.3 필요한 청크 파일 경로 추출하기
    -20.5.4 loadableReady와 hydrate
    20.6 서버 사이드 렌더링의 환경 구축을 위한 대안
    -20.6.1 Next.js
    -20.6.2 Razzle
    20.7 정리

    21장 백엔드 프로그래밍: Node.js의 Koa 프레임워크
    21.1 소개하기
    -21.1.1 백엔드
    -21.1.2 Node.js
    -21.1.3 Koa
    21.2 작업 환경 준비
    -21.2.1 Node 설치 확인
    -21.2.2 프로젝트 생성
    -21.2.3 ESLint와 Prettier 설정
    21.3 Koa 기본 사용법
    -21.3.1 서버 띄우기
    -21.3.2 미들웨어
    21.4 nodemon 사용하기
    21.5 koa-router 사용하기
    -21.5.1 기본 사용법
    -21.5.2 라우트 파라미터와 쿼리
    -21.5.3 REST API
    -21.5.4 라우트 모듈화
    -21.5.5 posts 라우트 생성
    21.6 정리

    22장 mongoose를 이용한 MongoDB 연동 실습
    22.1 소개하기
    -22.1.1 문서란?
    -22.1.2 MongoDB 구조
    -22.1.3 스키마 디자인
    22.2 MongoDB 서버 준비
    -22.2.1 설치
    -22.2.2 MongoDB 작동 확인
    22.3 mongoose의 설치 및 적용
    -22.3.1 .env 환경변수 파일 생성
    -22.3.2 mongoose로 서버와 데이터베이스 연결
    22.4 esm으로 ES 모듈 import/export 문법 사용하기
    -22.4.1 기존 코드 ES Module 형태로 바꾸기
    22.5 데이터베이스의 스키마와 모델
    -22.5.1 스키마 생성
    -22.5.2 모델 생성
    22.6 MongoDB Compass의 설치 및 사용
    22.7 데이터 생성과 조회
    -22.7.1 데이터 생성
    -22.7.2 데이터 조회
    -22.7.3 특정 포스트 조회
    22.8 데이터 삭제와 수정
    -22.8.1 데이터 삭제
    -22.8.2 데이터 수정
    22.9 요청 검증
    -22.9.1 ObjectId 검증
    -22.9.2 Request Body 검증
    22.10 페이지네이션 구현
    -22.10.1 가짜 데이터 생성하기
    -22.10.2 포스트를 역순으로 불러오기
    -22.10.3 보이는 개수 제한
    -22.10.4 페이지 기능 구현
    -22.10.5 마지막 페이지 번호 알려 주기
    -22.10.6 내용 길이 제한
    22.11 정리

    23장 JWT를 통한 회원 인증 시스템 구현하기
    23.1 JWT의 이해
    -23.1.1 세션 기반 인증과 토큰 기반 인증의 차이
    23.2 User 스키마/모델 만들기
    -23.2.1 모델 메서드 만들기
    -23.2.2 스태틱 메서드 만들기
    23.3 회원 인증 API 만들기
    -23.3.1 회원가입 구현하기
    -23.3.2 로그인 구현하기
    23.4 토큰 발급 및 검증하기
    -23.4.1 비밀키 설정하기
    -23.4.2 토큰 발급하기
    -23.4.3 토큰 검증하기
    -23.4.4 토큰 재발급하기
    -23.4.5 로그아웃 기능 구현하기
    23.5 posts API에 회원 인증 시스템 도입하기
    -23.5.1 스키마 수정하기
    -23.5.2 posts 컬렉션 비우기
    -23.5.3 로그인했을 때만 API를 사용할 수 있게 하기
    -23.5.4 포스트 작성 시 사용자 정보 넣기
    -23.5.5 포스트 수정 및 삭제 시 권한 확인하기
    23.6 username/tags로 포스트 필터링하기
    23.7 정리

    24장 프런트엔드 프로젝트: 시작 및 회원 인증 구현
    24.1 작업 환경 준비하기
    -24.1.1 설정 파일 만들기
    -24.1.2 라우터 적용
    -24.1.3 스타일 설정
    -24.1.4 Button 컴포넌트 만들기
    -24.1.5 리덕스 적용
    24.2 회원가입과 로그인 구현
    -24.2.1 UI 준비하기
    -24.2.2 리덕스로 폼 상태 관리하기
    -24.2.3 API 연동하기
    -24.2.4 회원가입 구현
    -24.2.5 로그인 구현
    -24.2.6 회원 인증 에러 처리하기
    24.3 헤더 컴포넌트 생성 및 로그인 유지
    -24.3.1 헤더 컴포넌트 만들기
    -24.3.2 로그인 상태를 보여 주고 유지하기
    -24.3.3 로그아웃 기능 구현
    24.4 정리

    25장 프런트엔드 프로젝트: 글쓰기 기능 구현하기
    25.1 에디터 UI 구현하기
    25.2 에디터 하단 컴포넌트 UI 구현하기
    -25.2.1 TagBox 만들기
    25.3 리덕스로 글쓰기 상태 관리하기
    -25.3.1 EditorContainer 만들기
    -25.3.2 TagBoxContainer 만들기
    -25.3.3 글쓰기 API 연동하기
    25.4 정리

    26장 프런트엔드 프로젝트: 포스트 조회 기능 구현하기
    26.1 포스트 읽기 페이지 구현하기
    -26.1.1 PostViewer UI 준비하기
    -26.1.2 API 연동하기
    26.2 포스트 목록 페이지 구현하기
    -26.2.1 PostList UI 준비하기
    -26.2.2 포스트 목록 조회 API 연동하기
    -26.2.3 HTML 필터링하기
    -26.2.4 페이지네이션 구현하기
    26.3 정리

    27장 프런트엔드 프로젝트: 수정/삭제 기능 구현 및 마무리
    27.1 포스트 수정
    -27.1.1 PostActionButtons 컴포넌트 만들기
    -27.1.2 수정 버튼 클릭 시 글쓰기 페이지로 이동하기
    27.2 포스트 삭제
    27.3 react-helmet-async로 meta 태그 설정하기
    27.4 프로젝트 마무리
    -27.4.1 프로젝트 빌드하기
    -27.4.2 koa-static으로 정적 파일 제공하기
    -27.4.3 더 할 수 있는 작업
    27.5 정리

    28장 그다음은?
    28.1 리액트 관련 커뮤니티
    -28.1.1 국내 커뮤니티
    -28.1.2 국외 커뮤니티
    28.2 책의 연장선
    28.3 사이드 프로젝트 생성

    찾아보기

    본문중에서

    이 책의 목표는 단순히 리액트를 다루는 기술을 습득하는 데 머무는 것이 아니라 독자로 하여금 더욱 즐겁고 편하게 웹 개발을 하도록 해 주는 것입니다. 그리고 웹 개발에 필요한 주요 지식을 다루어 여러분이 만들고 싶은 프로젝트를 실제로 개발할 수 있도록 경험치를 쌓아 주는 것이죠.
    개정판을 집필하면서 정말 많은 내용이 달라졌습니다. 2019년 초 리액트 16.8 버전에 Hooks라는 기능이 도입되면서 리액트 컴포넌트 개발 방식에 매우 큰 변화가 생겼습니다. 기존에는 컴포넌트에서 상태 관리를 하려면 반드시 클래스형 컴포넌트를 만들어서 사용해야 했지만, 이제는 Hooks를 사용하여 함수형 컴포넌트에서도 상태 관리를 할 수 있게 되었습니다. 또한, 리액트 컴포넌트의 라이프사이클(LifeCycle) 메서드를 대체할 수 있는 Hooks도 있어서 더 이상 클래스형 컴포넌트를 사용할 이유가 없습니다. 이에 맞춰, 책에 사용된 주요 예시를 모두 함수형 컴포넌트 형태로 전환했습니다.
    이 책으로 리액트 개발 방법을 충분히 익히고 난 다음에는 이 책에서 배운 것을 응용하여 여러분이 만들고 싶은 프로젝트를 구상해서 개발해 보는 것을 적극 권장합니다. 최고의 학습 방법은 직접 무언가를 처음부터 설계하고 마지막까지 완성해 보는 것이라 생각하며, 저 또한 이러한 방식으로 개발 공부를 해 왔기 때문입니다.
    ('지은이 서문' 중에서)

    관련이미지

    저자소개

    생년월일 -
    출생지 -
    출간도서 1종
    판매수 362권

    애니메이션 스트리밍 서비스를 제공하는 라프텔(laftel.net)에서 프런트엔드 엔지니어로 일하고 있고, 패스트캠퍼스의 리액트로 구현하는 웹 애플리케이션 제작 캠프에서 강의를 하고 있다. 리액트의 빅 팬이고, velopert.com 블로그를 운영하고 있으며, 유튜브에서 매일 밤 라이브 코딩(velopert의 코딩 이야기)을 하고 있다.

    - 블로그 https://velopert.com
    - 깃허브 https://github.com/velopert

    이 책과 내용이 비슷한 책 ? 내용 유사도란? 이 도서가 가진 내용을 분석하여 기준 도서와 얼마나 많이 유사한 콘텐츠를 많이 가지고 있는가에 대한 비율입니다.

      리뷰

      0.0 (총 0건)

      기대평

      작성시 유의사항

      평점
      0/200자
      등록하기

      기대평

      10.0

      교환/환불

      교환/환불 방법

      ‘마이페이지 > 취소/반품/교환/환불’ 에서 신청함, 1:1 문의 게시판 또는 고객센터(1577-2555) 이용 가능

      교환/환불 가능 기간

      고객변심은 출고완료 다음날부터 14일 까지만 교환/환불이 가능함

      교환/환불 비용

      고객변심 또는 구매착오의 경우에만 2,500원 택배비를 고객님이 부담함

      교환/환불 불가사유

      반품접수 없이 반송하거나, 우편으로 보낼 경우 상품 확인이 어려워 환불이 불가할 수 있음
      배송된 상품의 분실, 상품포장이 훼손된 경우, 비닐랩핑된 상품의 비닐 개봉시 교환/반품이 불가능함

      소비자 피해보상

      소비자 피해보상의 분쟁처리 등에 관한 사항은 소비자분쟁해결기준(공정거래위원회 고시)에 따라 비해 보상 받을 수 있음
      교환/반품/보증조건 및 품질보증 기준은 소비자기본법에 따른 소비자 분쟁 해결 기준에 따라 피해를 보상 받을 수 있음

      기타

      도매상 및 제작사 사정에 따라 품절/절판 등의 사유로 주문이 취소될 수 있음(이 경우 인터파크도서에서 고객님께 별도로 연락하여 고지함)

      배송안내

      • 인터파크 도서 상품은 택배로 배송되며, 출고완료 1~2일내 상품을 받아 보실 수 있습니다

      • 출고가능 시간이 서로 다른 상품을 함께 주문할 경우 출고가능 시간이 가장 긴 상품을 기준으로 배송됩니다.

      • 군부대, 교도소 등 특정기관은 우체국 택배만 배송가능하여, 인터파크 외 타업체 배송상품인 경우 발송되지 않을 수 있습니다.

      • 배송비

      도서(중고도서 포함) 구매

      2,000원 (1만원이상 구매 시 무료배송)

      음반/DVD/잡지/만화 구매

      2,000원 (2만원이상 구매 시 무료배송)

      도서와 음반/DVD/잡지/만화/
      중고직배송상품을 함께 구매

      2,000원 (1만원이상 구매 시 무료배송)

      업체직접배송상품 구매

      업체별 상이한 배송비 적용