최근 React를 다시 공부하게 되면서 올해 초에 회사에서 세미나를 하게 되었습니다. 물론 기초이지만 React에 관심을 다시 가지게 되는 계기가 되었습니다.
React란?
React는 페이스북에서 제공해 주는 프런트엔드 라이브러리입니다. 사용자 인터페이스(User Interface)에 집중하며, Virtual DOM을 통해 속도와 편의를 높이고, 단방향 데이터 플로우를 지원하여 보일러플레이트 코드를 감소 시켜줍니다. React는 싱글 페이지 애플리케이션(SPA)이나 모바일 애플리케이션을 개발할 때 사용할 수 있습니다.
특징
- 컴포넌트 기반 아키텍처
- 템플릿 언어가 아닌 자바스크립트로 컴포넌트 작성
- 특정 관심사에 집중된 기능 블록 (관심사의 분리)
- One Way Data flow(단방향 데이터 흐름 지향) - React는 데이터의 흐름이 한 방향으로만 흐릅니다. - 데이터가 내려가기만 하고 밑에서 데이터를 올릴 수 없습니다. - 그래서 부모의 데이터를 바꿔주기 위해서는
state
를 이용해야 합니다. - Virtual DOM - React는 가상의 DOM을 만들어서 진짜 DOM과 비교하여 변경 사항이 있을 경우 전체를 새롭게 만드는 것이 아니라 변경된 부분만 진짜 DOM에 반영하는 방식으로 작업을 수행합니다. 그럼으로써 애플리케이션의 효율성과 속도를 높일 수 있게 됩니다.
- JSX 문법
리액트 JS를 하기 위해 알아야 할 것
- Javascript(ES6)
- HTML
- CSS
Fundamentals(기초)
React에서 많이 사용되는 자바스크립트 ES6 문법 기초를 먼저 알아봅시다.
- 기존에 우리가 웹 개발에서 많이 보던 자바스크립트는 2009년 12월에 나온 ECMAScript5(ES5) 버전입니다. 최근 Node.js, react에서는 2015년 6월에 업데이트된 ECMAScript6(ES6) 문법의 자바스크립트를 사용하고 있습니다.
- ES6 문법을 사용하면서 처음에는 익숙해지기 어려웠지만 사용할 수록 코드가 간결해지고 깔끔해지면서 가독성이 좋아졌고, 모듈 별로 개발하면서 코드 관리가 쉬워졌습니다.
- 현재는 ES8까지 업데이트 되었지만 몇 가지 걸림돌이 있어 넘어가지 않고 있습니다.
아래에는 바뀐 ES6 문법과 많이 사용되는 기능들입니다.
var -> let & const
const 는 블록 범위이며 값이 지정되면 나중에 바꿀 수 없습니다. 또한, 재 선언 될 수도 없습니다.
let 은 블록 범위이며 값이 지정되어도 값을 바꿀 수 있습니다.
const name = 'hgko';
let tel = '010-0000-0000';
Arrow Functions
함수는 간결해지고 코드는 짧아졌습니다.
Argument가 하나 일 때는 괄호가 필요 없습니다.(유일한 규칙)
// ES5
function sayHello(name) {
reutn "Hello " + name;
}
// ES6
const sayHello = name => "Hello " + name;
const sayHello = (name, something) => "Hello " + name + something;
Template Literals
``(backticks) 사용
const name = 'hgko';
// ES5
console.log('Hello ' + name);
// ES6
console.log(`Hello ${name}`);
Object Destructuring (비구조화)
적은 코드를 사용해서 더 깔끔하게 보이도록 합니다.
const human = {
name: 'Ko',
lastName: 'HyeongGyun',
nationality: 'Korea',
favFood: {
dinner: 'Samgyupsal',
},
};
// ES5
const name = human.name;
const lastName = human.lastName;
const difName = human.nationality;
const dinner = human.favFood.dinner;
// ES6
const {
name,
lastName,
nationality: difName,
favFood: { dinner },
} = human;
console.log(name, lastName, difName, dinner);
Spread Operator
Iterable Object(열거 가능한 오브젝트)를 하나씩 전개합니다.
표현방식 […iterable], 변수 앞에 '…' 찍어서 선언합니다.
변수뿐만 아니라 Argument, Function에서도 쓰입니다.
const days = ['Mon', 'Tues', 'Wed'];
const otherDays = ['Thu', 'Fri', 'Sat'];
const allDays = [...days, ...otherDays, 'Sun'];
console.log(allDays);
결과: ['Mon', 'Tues', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'];
Classes
constructor 메서드도 사용할 수 있고 extends를 통해서 클래스 상속도 가능합니다.
class Human {
constructor(name, lastName) {
this.name = name;
this.lastName = lastName;
}
}
class Baby extends Human {
cry() {
console.log('cry');
}
sayName() {
console.log(`My name is ${this.name}`);
}
}
const myBaby = new Baby('mini', 'me');
console.log(myBaby.cry(), myBaby.sayName());
Array.map
요소를 일괄적으로 변경합니다.
const days = ['Mon', 'Tues', 'Wed', 'Thu', 'Fri'];
const smilingDays = days.map((day) => `😂 ${day}`);
console.log(smilingDays);
결과: ['😂 Mon', '😂 Tues', '😂 Wed', '😂 Thu', '😂 Fri'];
Array.filter
요소를 걸러내어 배열로 true/false 반환, 없으면 빈 배열을 반환합니다.
const numbers = [123, 5, 15, 67, 241, 54, 1, 6, 23, 90];
const otherNumbers = numbers.filter((number) => number > 15);
console.log(otherNumbers);
forEach, includes, push
let posts = ['Hi', 'Hello', 'Bye'];
if (!posts.includes('new')) {
posts.push('new');
}
posts.forEach((post) => console.log(post));
CodeSandbox
- 웹 기반 자바스크립트 에디터 서비스를 제공하는 사이트
- 간단한 소스 코드 테스트를 할 때 사용하면 편리합니다.
- codesandbox.io
참고
- https://velog.io/@stampid/React%EB%9E%80
- https://velog.io/@kyusung/react-summary
- https://hgko1207.github.io/2019/01/09/react-start/
- https://sanghaklee.tistory.com/54
- http://woowabros.github.io/experience/2017/12/01/es6-experience.html
- https://blog.asamaru.net/2017/08/14/top-10-es6-features/
- https://velog.io/@decody/map-%EC%A0%95%EB%A6%AC
'Frontend > React' 카테고리의 다른 글
[React] TypeScript 사용 방법 (1) | 2022.10.05 |
---|---|
[React] Styled Components 사용 방법 (0) | 2022.10.05 |
[React] UI 추천 (0) | 2022.08.30 |
React Study(2) (1) | 2022.08.29 |
[React] 설치 및 설정 방법 (0) | 2022.08.26 |
IT 기술과 개발 내용을 포스팅하는 블로그
포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!