웹 애플리케이션의 규모가 커지고 다양한 UI,UX를 구현하게 되면서 이전의 방법으로는 애플리케이션을 개발하고 유지보수하는 것이 어려워졌다. 규모가 커지고 복잡한 애플리케이션을 개발하며 생산성을 향상시키고, 많은 양의 데이터 관리와 코드 유지보수를 더욱 편리하기 위해 다양한 Frontend Framework(Library)가 등장하게 된 것이다.
2010년 구글에서 개발한 프레임워크, TypeScript 기반으로 매우 안정적이고 탄탄한 프론트엔드 앱 개발이 가능하며 다양한 기능이 내장되어있다. 무겁고 배우기 어렵다는 단점이 있다.
2014년 Evan You라는 개인이 개발한 프레임워크, 코드가 깔끔하고 배우기 쉽기 때문에 가장 나중에 생겼으나 성장 속도가 매우 빠르다.
지속적으로 데이터가 변화하는 대규모 애플리케이션을 구축하는 것을 목표로 2013년 Facebook에서 개발한 라이브러리. MVC(Model-View-Controller) Architecture인 Angular, Vue 와는 달리 리액트는 오직 View만 담당한다.
그만큼 내장된 기능이 부족해 third-party 라이브러리 (ex. React-router, Redux)를 함께 사용한다. 생태계가 활성화 되어 있으며 다양한 자료와 React Native의 사용으로 사용자가 꾸준히 증가하고 있다.
페이스북에서 개발하고 관리하는 사용자 인터페이스를 만들기 위한 JavaScript 라이브러리. 리액트는 가상 돔(Virtual Dom)을 통해 UI를 자동으로 빠르게 업데이트한다. 가상 돔은 이전 UI 상태를 메모리에 유지해서 변경될 UI의 최소 집합을 계산하는 기술이다!
: 리액트 프로젝트를 시작하는데 필요한 개발 환경을 세팅 해주는 도구(toolchain)
리액트는 UI 기능만 제공한다. 따라서 개발자가 직접 구축해야하는 것들이 많다. 전반적인 스스템을 직접 구축할 수 있으니 원하는 환경에 맞게 최적화할 수 있지만, 반대로 신경쓸 것이 많기 때문에 처음 시작하는 단계에서는 직접 개발 환경을 구축하기 어려울 수 있다.
리액트 팀에서는 이러한 문제를 해결하기 위해 CRA(Create-React-App)
을 만들었다. CRA는 리액트로 웹 애플리케이션을 만들기 위한 환경을 제공한다. CRA를 이용하면 하나의 명령어로 리액트 개발환경을 구축할 수 있다.
CRA에는 바벨(compiler)과 웹팩(bundler)과 같이 리액트 애플리케이션 실행에 필요한 다양한 패키지가 포함되어 있으며, 테스트 시스템, ES6+ 문법, CSS 후처리 등 거의 필수라고 할 수 있는 개발 환경도 구축해 준다. 이러한 개발 환경을 직접 구축할 경우 시간이 오래 걸릴 뿐 아니라 유지 보수도 해야한다. CRA를 이용하면 개발 환경 세팅을 해주기 때문에 기존 기능을 개선하거나 새로운 기능을 추가했을 때 패키지 버전만 올리면 된다.
jsx
// 1. Desktop - wecode 폴더 진입
cd Desktop/wecode
// 2. westagram-react 프로젝트 설치
npx create-react-app westagram-react
// 3. westagram-react 프로젝트 진입
cd westagram-react
// 4. 로컬 서버 띄우기
npm start
//5. 서버 끊기
콘솔창에서 Ctrl + C
필요 없는 파일 및 주석 처리되어 있는 코드는 삭제한다.
1) node.modules
2) package.json
"dependencies"
node.modules
폴더에 존재node.modules
는 올리지 않는다. 다른 사람이 pull
받아서 npm install
만 하면 package.json
에 기록되어있는 패키지를 버전에 맞게 자동으로 설치한다."scripts"
npm run start
.3) .gitignore
.gitignore
파일에 github 에 올리고 싶지 않은 폴더와 파일을 작성할 수 있다.push
를 해도 .gitignore
파일에 작성된 폴더와 파일은 올라가지 않는다.1) public - index.html
<div id="root"></div>
2) src - index.js
ReactDOM.render( <App /> , document.getElementById('root'))
3) src - App.js
<Login />
컴포넌트, <Main />
컴포넌트를 그 자리에 대체하여 작업하면 된다.<Routes />
컴포넌트가 최상위 컴포넌트로 그 자리에 위치하게 된다.1) public 폴더
2) src 폴더
Login.js
, Login.scss
Main.js
, Main.scss
reset.scss
- css 초기화commom.scss
- 공통으로 사용하는 css 속성 정의 (ex. font-family, theme color)