본문 바로가기

추천 검색어

실시간 인기 검색어

리액트를 다루는 기술

입문부터 대규모 애플리케이션까지 한 권으로 | 개정판
김민준 저자(글)
길벗 · 2019년 08월 31일
가장 최근에 출시된 개정판입니다. 구판보기
9.5 (73개의 리뷰)
집중돼요 (41%의 구매자)
  • 리액트를 다루는 기술 대표 이미지
    리액트를 다루는 기술 대표 이미지
  • A4
    사이즈 비교
    210x297
    리액트를 다루는 기술 사이즈 비교 182x234
    단위 : mm
MD의 선택 무료배송 이벤트 소득공제 분철서비스
10% 37,800 42,000
적립/혜택
2,100P

기본적립

5% 적립 2,100P

추가적립

  • 5만원 이상 구매 시 추가 2,000P
  • 3만원 이상 구매 시, 등급별 2~4% 추가 최대 2,100P
  • 리뷰 작성 시, e교환권 추가 최대 300원
배송안내
무료배송
배송비 안내
국내도서/외국도서
도서만 15,000원 이상 구매 시 무료배송
도서+교보Only(교보배송)을 함께 15,000원 이상 구매 시 무료배송

15,000원 미만 시 2,500원 배송비 부과

교보Only(교보배송)
각각 구매하거나 함께 20,000원 이상 구매 시 무료배송

20,000원 미만 시 2,500원 배송비 부과

해외주문 서양도서/해외주문 일본도서(교보배송)
각각 구매하거나 함께 15,000원 이상 구매 시 무료배송

15,000원 미만 시 2,500원 배송비 부과

업체배송 상품(전집, GIFT, 음반/DVD 등)
해당 상품 상세페이지 "배송비" 참고 (업체 별/판매자 별 무료배송 기준 다름)
바로드림 오늘배송
업체에서 별도 배송하여 1Box당 배송비 2,500원 부과

1Box 기준 : 도서 10권

그 외 무료배송 기준
바로드림, eBook 상품을 주문한 경우, 플래티넘/골드/실버회원 무료배송쿠폰 이용하여 주문한 경우, 무료배송 등록 상품을 주문한 경우
주문정보를 불러오는 중입니다.
서울시 종로구 종로 1

분철옵션 선택 시, 예상 출고일보다 3일 추가 기간 소요

분철서비스 안내보기

알림 신청하시면 원하시는 정보를
받아 보실 수 있습니다.

알립니다.

  • 분철도서의 경우 취소/반품은 어렵습니다. 이 점 양해 부탁드립니다.

해외주문/바로드림/제휴사주문/업체배송건의 경우 1+1 증정상품이 발송되지 않습니다.

패키지

북카드

키워드 Pick

키워드 Pick 안내

관심 키워드를 주제로 다른 연관 도서를 다양하게 찾아 볼 수 있는 서비스로, 클릭 시 관심 키워드를 주제로 한 다양한 책으로 이동할 수 있습니다.
키워드는 최근 많이 찾는 순으로 정렬됩니다.

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

작가정보

저자(글) 김민준

개발은 언제나 즐겁고 재밌어야 한다는 생각을 갖고 있는 개발자이며, IT 기술을 가르치는 것을 굉장히 좋아하는 교육자이기도 합니다. 또한, 사용자를 행복하게 만드는 서비스를 만드는 것이 가장 중요하다고 여깁니다. 현재 리디(주)에서 애니메이션 스트리밍 서비스 라프텔(laftel.net)의 프런트엔드 개발을 하고 있습니다. 그리고 개발자들의 블로그 서비스인 벨로그(velog.io)를 운영 및 개발하고 있습니다.
블로그: https://velog.io/@velopert
GitHub: https://github.com/velopert

목차

  • 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위

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

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

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

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

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

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

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

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

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

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

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

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

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

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

기본정보

상품정보
ISBN 9791160508796
발행(출시)일자 2019년 08월 31일
쪽수 908쪽
크기
182 * 234 * 45 mm / 1614 g
총권수 1권
이 책의 개정정보
가장 최근에 출시된 개정판입니다. 구판보기

Klover

Klover 리뷰 안내
교보를 애용해 주시는 고객님들이 남겨주신 평점과 감상을 바탕으로, 다양한 정보를 전달하는 교보문고의 리뷰 서비스입니다.
1.리워드 안내
구매 후 90일 이내에 평점과 10자 이상의 리뷰 작성 시 e교환권 200원을 적립해 드립니다.
e교환권은 적립 일로부터 180일 동안 사용 가능합니다.
리워드는 작성 후 다음 날 제공되며, 발송 전 작성 시 발송 완료 후 익일 제공됩니다.
리워드는 리뷰 종류별로 구매한 아이디당 한 상품에 최초 1회 작성 건들에 대해서만 제공됩니다.
판매가 1,000원 미만 도서의 경우 리워드 지급 대상에서 제외됩니다.
한달 후 리뷰
구매 후 30일~ 120일 이내에 작성된 두 번째 구매리뷰에 대해 한 달 후 리뷰로 인지하고 e교환권 100원을 추가 제공합니다.

* 강연, 공연, 여행, 동영상, 사은품, 기프트카드 상품은 지급 제외
2.운영 원칙 안내
Klover 리뷰를 통한 리뷰를 작성해 주셔서 감사합니다. 자유로운 의사 표현의 공간인 만큼 타인에 대한 배려를 부탁합니다.
일부 타인의 권리를 침해하거나 불편을 끼치는 것을 방지하기 위해 아래에 해당하는 Klover 리뷰는 별도의 통보 없이 삭제될 수 있습니다.
  • 도서나 타인에 대해 근거 없이 비방을 하거나 타인의 명예를 훼손할 수 있는 리뷰
  • 도서와 무관한 내용의 리뷰
  • 인신공격이나 욕설, 비속어, 혐오발언이 개재된 리뷰
  • 의성어나 의태어 등 내용의 의미가 없는 리뷰

리뷰는 1인이 중복으로 작성하실 수는 있지만, 평점계산은 가장 최근에 남긴 1건의 리뷰만 반영됩니다.
3.신고하기
다른 고객이 작성리뷰에 대해 불쾌함을 느끼는 경우 신고를 할 수 있으며, 신고 자가 일정수준 이상 누적되면 작성하신 리뷰가 노출되지 않을 수 있습니다.

구매 후 리뷰 작성 시, e교환권 200원 적립

문장수집

문장수집 안내
문장수집은 고객님들이 직접 선정한 책의 좋은 문장을 보여주는 교보문고의 새로운 서비스입니다. 마음을 두드린 문장들을 기록하고 좋은 글귀들은 "좋아요“ 하여 모아보세요. 도서 문장과 무관한 내용 등록 시 별도 통보 없이 삭제될 수 있습니다.
리워드 안내
구매 후 90일 이내에 문장수집 작성 시 e교환권 100원을 적립해드립니다.
e교환권은 적립 일로부터 180일 동안 사용 가능합니다. 리워드는 작성 후 다음 날 제공되며, 발송 전 작성 시 발송 완료 후 익일 제공됩니다.
리워드는 한 상품에 최초 1회만 제공됩니다.
주문취소/반품/절판/품절 시 리워드 대상에서 제외됩니다.

구매 후 리뷰 작성 시, e교환권 100원 적립

이 책의 첫 기록을 남겨주세요

교환/반품/품절 안내

상품 설명에 반품/교환 관련한 안내가 있는 경우 그 내용을 우선으로 합니다. (업체 사정에 따라 달라질 수 있습니다.)

이벤트
TOP

저자 모두보기

저자(글)

매장별 재고 및 도서위치

할인쿠폰 다운로드

  • 쿠폰은 주문결제화면에서 사용 가능합니다.
  • 다운로드한 쿠폰은 마이 > 나의 통장 에서 확인 가능합니다.
  • 도서정가제 적용 대상 상품에 대해서는 정가의 10%까지 쿠폰 할인이 가능합니다.
  • 도서정가제 적용 대상 상품에 10% 할인이 되었다면, 해당 상품에는 사용하실 수
    없습니다.

적립예정포인트 안내

  • 통합포인트 안내

    • 통합포인트는 교보문고(인터넷, 매장), 핫트랙스(인터넷, 매장), 모바일 교보문고 등 다양한 곳에서 사용하실 수 있습니다.
    • 상품 주문 시, 해당 상품의 적립률에 따라 적립 예정 포인트가 자동 합산되고 주문하신 상품이 발송완료 된 후에 자동으로 적립됩니다.
    • 단, 쿠폰 및 마일리지, 통합포인트, e교환권 사용 시 적립 예정 통합포인트가 변동될 수 있으며 주문취소나 반품시에는 적립된 통합포인트가 다시 차감됩니다.
  • 통합포인트 적립 안내

    • 통합포인트는 도서정가제 범위 내에서 적용됩니다.
    • 추가적립 및 회원 혜택은 도서정가제 대상상품(국내도서, eBook등)으로만 주문시는 해당되지 않습니다.
  • 기본적립) 상품별 적립금액

    • 온라인교보문고에서 상품 구매시 상품의 적립률에 따라 적립됩니다.
    • 단 도서정가제 적용 대상인 국내도서,eBook은 15%내에서 할인율을 제외한 금액내로 적립됩니다.
  • 추가적립) 5만원 이상 구매시 통합포인트 2천원 추가적립

    • 5만원 이상 구매시 통합포인트 2천원 적립됩니다.
    • 도서정가제 예외상품(외서,음반,DVD,잡지(일부),기프트) 2천원 이상 포함시 적립 가능합니다.
    • 주문하신 상품이 전체 품절인 경우 적립되지 않습니다.
  • 회원혜택) 3만원이상 구매시 회원등급별 2~4% 추가적립

    • 회원등급이 플래티넘, 골드, 실버 등급의 경우 추가적립 됩니다.
    • 추가적립은 실결제액 기준(쿠폰 및 마일리지, 통합포인트, e교환권 사용액 제외) 3만원 이상일 경우 적립됩니다.
    • 주문 후 취소,반품분의 통합포인트는 단품별로 회수되며, 반품으로 인해 결제잔액이 3만원 미만으로 변경될 경우 추가 통합포인트는 전액 회수될 수 있습니다.

제휴 포인트 안내

제휴 포인트 사용

  • OK CASHBAG 10원 단위사용 (사용금액 제한없음)
  • GS&POINT 최대 10만 원 사용
더보기

구매방법 별 배송안내

지역별 도착 예정일

수도권 지역

배송 일정 안내 테이블로 결제 완료 시간, 도착예정일 결제 완료 시간 컬럼의 하위로 평일 0시 ~ 12시 토요일 0시 ~ 11시 평일 12시 ~ 22시 평일 12시 ~ 24시 토요일 11시 ~ 21시 을(를) 나타낸 표입니다.
결제 완료 시간 도착예정일
평일 0시 ~ 12시

토요일 0시 ~ 11시
당일배송 오늘

당일배송 오늘
평일 12시 ~ 22시

평일 12시 ~ 24시

토요일 11시 ~ 21시
새벽배송 내일 07시 이전

내일

일요배송 일요일

수도권 외 (천안, 대전, 울산, 부산, 대구, 창원)

배송 일정 안내 테이블로 결제 완료 시간, 도착예정일 결제 완료 시간 컬럼의 하위로 월~토 0시 ~ 11시 30분 을(를) 나타낸 표입니다.
결제 완료 시간 도착예정일
월~토 0시 ~ 11시 30분
당일배송 오늘

배송 유의사항

  • 새벽배송과 일요배송은 수도권 일부 지역을 대상으로 합니다. 상품 상세페이지에서 도착 예정일을 확인해 주세요.
  • 수도권 외 지역에서 선물포장하기 또는 사은품을 포함하여 주문할 경우 당일배송 불가합니다.
  • 무통장입금 주문 후 당일 배송 가능 시간 이후 입금된 경우 당일 배송 불가합니다.
  • 새벽배송의 경우 공동 현관 출입 번호가 누락 되었거나 틀릴 경우 요청하신 방법으로 출입이 어려워, 부득이하게 공동 현관 또는 경비실 앞에 배송 될 수 있습니다.
  • 학교, 관공서, 회사 등 출입 제한 시간이 있는 곳은 당일배송, 새벽배송, 일요배송이 제공되지 않을 수 있습니다.
  • 공휴일과 겹친 토요일, 일요일은 일요일 배송에서 제외됩니다. 일요배송은 한정 수량에 한해 제공됩니다. 수량 초과 시 일반배송으로 발송되니 주문 시 도착 예정일을 확인해 주세요.
  • 주문 후 배송지 변경 시 변경된 배송지에 따라 익일 배송될 수 있습니다.
  • 수도권 외 지역의 경우 효율적인 배송을 위해 각 지역 매장에서 택배를 발송하므로, 주문 시의 부록과 상이할 수 있습니다.
  • 각 지역 매장에서 재고 부족 시 재고 확보를 위해 당일 배송이 불가할 수 있습니다.
  • 기상악화로 인한 도로 사정으로 일부 지역의 배송 지연이 발생될 수 있습니다.
  • 출고 예정일이 5일 이상인 상품의 경우(결제일로부터 7일 동안 미입고), 출판사 / 유통사 사정으로 품/절판 되어 구입이 어려울 수 있습니다. 이 경우 SMS, 메일로 알려드립니다.
  • 분철상품 주문 시 분철 작업으로 인해 기존 도착 예정일에 2일 정도 추가되며, 당일 배송, 해외 배송이 불가합니다.
  • 해외주문도서는 해외 거래처 사정에 의해 품절/지연될 수 있습니다.
  • 스페셜오더 도서나 일서 해외 주문 도서와 함께 주문 시 배송일이 이에 맞추어 지연되오니, 이점 유의해 주시기 바랍니다.

바로드림존에서 받기

  1. STEP 01
    매장 선택 후 바로드림 주문
  2. STEP 02
    준비완료 알림 시 매장 방문하기
  3. STEP 03
    바로드림존에서 주문상품 받기
  • 바로드림은 전국 교보문고 매장 및 교내서점에서 이용 가능합니다.
  • 잡지 및 일부 도서는 바로드림 이용이 불가합니다.
  • 각 매장 운영시간에 따라 바로드림 이용 시간이 달라질 수 있습니다.

수령 안내

  • 안내되는 재고수량은 서비스 운영 목적에 따라 상이할 수 있으므로 해당 매장에 문의해주시기 바랍니다.
  • 바로드림 주문 후 재고가 실시간 변동되어, 수령 예상 시간에 수령이 어려울 수 있습니다.

취소/교환/반품 안내

  • 주문 후 7일간 찾아가지 않으시면, 자동으로 결제가 취소됩니다.
  • 취소된 금액은 결제수단의 승인취소 및 예치금으로 전환됩니다.
  • 교환/반품은 수령하신 매장에서만 가능합니다.

사은품 관련 안내

  • 바로드림 서비스는 일부 1+1 도서, 경품, 사은품 등이 포함 되지 않습니다.

음반/DVD 바로드림시 유의사항

  • 음반/DVD 상품은 바로드림 주문 후 수령점 변경이 불가합니다. 주문 전 수령점을 꼭 확인해 주세요.
  • 사은품(포스터,엽서 등)은 증정되지 않습니다.
  • 커버이미지 랜덤발매 음반은 버전 선택이 불가합니다.
  • 광화문점,강남점,대구점,영등포점,잠실점은 [직접 찾아 바로드림존 가기], [바로드림존에서 받기] 로 주문시 음반 코너에서 수령확인이 가능합니다
  • 선물 받는 분의 휴대폰번호만 입력하신 후 결제하시면 받는 분 휴대폰으로 선물번호가 전달됩니다.
  • 문자를 받은 분께서는 마이 > 주문관리 > 모바일 선물내역 화면에서 선물번호와 배송지 정보를 입력하시면 선물주문이 완료되어 상품준비 및 배송이 진행됩니다.
  • 선물하기 결제하신 후 14일까지 받는 분이 선물번호를 등록하지 않으실 경우 주문은 자동취소 됩니다.
  • 또한 배송 전 상품이 품절 / 절판 될 경우 주문은 자동취소 됩니다.

바로드림 서비스 안내

  1. STEP 01
    매장 선택 후 바로드림 주문
  2. STEP 02
    준비완료 알림 시 매장 방문하기
  3. STEP 03
    바로드림존에서 주문상품 받기
  • 바로드림은 전국 교보문고 매장 및 교내서점에서 이용 가능합니다.
  • 잡지 및 일부 도서는 바로드림 이용이 불가합니다.
  • 각 매장 운영시간에 따라 바로드림 이용 시간이 달라질 수 있습니다.

수령 안내

  • 안내되는 재고수량은 서비스 운영 목적에 따라 상이할 수 있으므로 해당 매장에 문의해주시기 바랍니다.
  • 바로드림 주문 후 재고가 실시간 변동되어, 수령 예상시간에 수령이 어려울 수 있습니다.

취소/교환/반품 안내

  • 주문 후 7일간 찾아가지 않으시면, 자동으로 결제가 취소됩니다.
  • 취소된 금액은 결제수단의 승인취소 및 예치금으로 전환됩니다.
  • 교환/반품은 수령하신 매장에서만 가능합니다.

사은품 관련 안내

  • 바로드림 서비스는 일부 1+1 도서, 경품, 사은품 등이 포함되지 않습니다.

음반/DVD 바로드림시 유의사항

  • 음반/DVD 상품은 바로드림 주문 후 수령점 변경이 불가합니다. 주문 전 수령점을 꼭 확인해주세요.
  • 사은품(포스터,엽서 등)은 증정되지 않습니다.
  • 커버이미지 랜덤발매 음반은 버전 선택이 불가합니다.
  • 광화문점,강남점,대구점,영등포점,잠실점은 [직접 찾아 바로드림존 가기], [바로드림존에서 받기] 로 주문시 음반코너에서 수령확인이 가능합니다.
  1. STEP 01
    픽업박스에서 찾기 주문
  2. STEP 02
    도서준비완료 후 휴대폰으로 인증번호 전송
  3. STEP 03
    매장 방문하여 픽업박스에서 인증번호 입력 후 도서 픽업
  • 바로드림은 전국 교보문고 매장 및 교내서점에서 이용 가능합니다.
  • 잡지 및 일부 도서는 바로드림 이용이 불가합니다.
  • 각 매장 운영시간에 따라 바로드림 이용 시간이 달라질 수 있습니다.

수령 안내

  • 안내되는 재고수량은 서비스 운영 목적에 따라 상이할 수 있으므로 해당 매장에 문의해주시기 바랍니다.
  • 바로드림 주문 후 재고가 실시간 변동되어, 수령 예상시간에 수령이 어려울 수 있습니다.

취소/교환/반품 안내

  • 주문 후 7일간 찾아가지 않으시면, 자동으로 결제가 취소됩니다.
  • 취소된 금액은 결제수단의 승인취소 및 예치금으로 전환됩니다.
  • 교환/반품은 수령하신 매장에서만 가능합니다.

사은품 관련 안내

  • 바로드림 서비스는 일부 1+1 도서, 경품, 사은품 등이 포함되지 않습니다.

음반/DVD 바로드림시 유의사항

  • 음반/DVD 상품은 바로드림 주문 후 수령점 변경이 불가합니다. 주문 전 수령점을 꼭 확인해주세요.
  • 사은품(포스터,엽서 등)은 증정되지 않습니다.
  • 커버이미지 랜덤발매 음반은 버전 선택이 불가합니다.
  • 광화문점,강남점,대구점,영등포점,잠실점은 [직접 찾아 바로드림존 가기], [바로드림존에서 받기] 로 주문시 음반코너에서 수령확인이 가능합니다.

도서 소득공제 안내

  • 도서 소득공제란?

    • 2018년 7월 1일 부터 근로소득자가 신용카드 등으로 도서구입 및 공연을 관람하기 위해 사용한 금액이 추가 공제됩니다. (추가 공제한도 100만원까지 인정)
      • 총 급여 7,000만 원 이하 근로소득자 중 신용카드, 직불카드 등 사용액이 총급여의 25%가 넘는 사람에게 적용
      • 현재 ‘신용카드 등 사용금액’의 소득 공제한도는 300만 원이고 신용카드사용액의 공제율은 15%이지만, 도서·공연 사용분은 추가로 100만 원의 소득 공제한도가 인정되고 공제율은 30%로 적용
      • 시행시기 이후 도서·공연 사용액에 대해서는 “2018년 귀속 근로소득 연말 정산”시기(19.1.15~)에 국세청 홈택스 연말정산간소화 서비스 제공
  • 도서 소득공제 대상

    • 도서(내서,외서,해외주문도서), eBook(구매)
    • 도서 소득공제 대상 상품에 수반되는 국내 배송비 (해외 배송비 제외)
      • 제외상품 : 잡지 등 정기 간행물, 음반, DVD, 기프트, eBook(대여,학술논문), 사은품, 선물포장, 책 그리고 꽃
      • 상품정보의 “소득공제” 표기를 참고하시기 바랍니다.
  • 도서 소득공제 가능 결제수단

    • 카드결제 : 신용카드(개인카드에 한함)
    • 현금결제 : 예치금, 교보e캐시(충전에한함), 해피머니상품권, 컬쳐캐쉬, 기프트 카드, 실시간계좌이체, 온라인입금
    • 간편결제 : 교보페이, 네이버페이, 삼성페이, 카카오페이, PAYCO, 토스, CHAI
      • 현금결제는 현금영수증을 개인소득공제용으로 신청 시에만 도서 소득공제 됩니다.
      • 교보e캐시 도서 소득공제 금액은 교보eBook > e캐시 > 충전/사용내역에서 확인 가능합니다.
      • SKpay, 휴대폰 결제, 교보캐시는 도서 소득공제 불가
  • 부분 취소 안내

    • 대상상품+제외상품을 주문하여 신용카드 "2회 결제하기"를 선택 한 경우, 부분취소/반품 시 예치금으로 환원됩니다.

      신용카드 결제 후 예치금으로 환원 된 경우 승인취소 되지 않습니다.

  • 도서 소득공제 불가 안내

    • 법인카드로 결제 한 경우
    • 현금영수증을 사업자증빙용으로 신청 한 경우
    • 분철신청시 발생되는 분철비용

알림 신청

아래의 알림 신청 시 원하시는 소식을 받아 보실 수 있습니다.
알림신청 취소는 마이룸 > 알림신청내역에서 가능합니다.

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

신고 사유를 선택해주세요.
신고 내용은 이용약관 및 정책에 의해 처리됩니다.

허위 신고일 경우, 신고자의 서비스 활동이 제한될 수 있으니 유의하시어
신중하게 신고해주세요.

판형알림

  • A3 [297×420mm]
  • A4 [210×297mm]
  • A5 [148×210mm]
  • A6 [105×148mm]
  • B4 [257×364mm]
  • B5 [182×257mm]
  • B6 [128×182mm]
  • 8C [8절]
  • 기타 [가로×세로]
EBS X 교보문고 고객님을 위한 5,000원 열공 혜택!
자세히 보기

해외주문양서 배송지연 안내

현재 미국 현지 눈폭풍으로 인해
해외 거래처 출고가 지연되고 있습니다.

해외주문양서 주문 시
예상 출고일보다 배송기간이 더 소요될 수 있으니
고객님의 너그러운 양해 부탁드립니다.

감사합니다.