패스트캠퍼스

2020-01-14 React강좌 첫 수업 - 리액트를 위한 JS, 환경설정, 기초

sunnykim91 2020. 1. 14. 21:50

이웅제 강사님( Mark Lee ) 

프로토파이 회사에서 일하고 계심.

Microsoft MVP로 활동.

TypeScript Korea User Group Organizer

Electron Korea User Group Organizer

Youtube : Marktube 운영중

 

 

 

리액트를 위한 JS 정리

 

var는 문제아

 - 함수 레벨 스코프만 지원

 - 중복 선언 가능

 - 생략도 가능

 - 호이스팅 

-> let은 해결사 : 블록 레벨 스코프 중복선언이나 호이스팅할때 에러발생해서 알려준다.

SyntaxError - 문법적으로 오류, ReferenceError 참조 에러 

 

let은 변경 가능 ( 값 자체와 참조값이 변경가능) 

const는 불가능

Primitive(원시값) vs Reference(객체)

 

참고: 

https://overreacted.io/on-let-vs-const/

 

On let vs const

So which one should I use?

overreacted.io

 

 

템플릿 String

`` (백틱) 사용 

console.log(`안녕하세요 제이름은 ${name} 입니다.`);

 

arrow function

자신의 this를 만들지 않는다.

생성자로 사용할 수 없다. ( 자신의 this를 생성할 수 없다.)

항상 익명 함수 ( 함수의 이름이 없음 IIFE같은것)

리턴만 있으면, {} 생략 가능

인자가 하나면, () 생략 가능

 

function Foo() {
  this.name = 'a'

  setTimeout(function () {
    console.log(this.name);   // undefined
  }, 1000);

  setTimeout(() => {
    console.log(this.name);  // a를 가르킴
  }, 1000);
}


const foo = new FOO();
const a = () => {
  return '리턴';
};

console.log(a());

const b = () => '리턴';

console.log(b());

const c = props => `리턴 ${props}`;

console.log(c('프롭스'));

 

 

함수.bind(디스)

함수의 this로 인자로 넣은 '디스' 를 사용하는 함수를 만들어 리턴

 

Desturcturing assign

구조분해 할당

 

const foo = {
  a: '에이',
  b: '비이'
};

const { a, b } = foo;
console.log(a, b);

const bar = ['씨이', '디이'];

const [c, d] = bar;

 

 

Spread문법

 

callback

함수를 인자로 넘기는 행위 , 비동기처리를 위해 이 과정을 했음.

 

Promist 객체

Promise 객체를 마들고, 로직 처리 후 성공과 실패를 알려준다.

thien과 catch 를 통해 메인 로직에 전달한다.

 

요 개념이 있어야 async, await로 넘어가기 직전 들르는 곳

 

 

async - await

기본적으로 promist사용

then과 catch를 통해 메인 로직에 전달한다.

async키워드가 붙은 함수 안에서만 await 사용가능

 

Generator 객체

function*으로 만들어진 함수를 호출하면 반환되는 객체이다.

function* 에서 yield를 호출하여, 다시 제어권을 넘겨준다.

제너레이터 객체에 next()함수를 호출하면, 다음 yield 지점까지 간다.

 

 

 

CRA

create react app

 

왜 npx가 필요했을까

 

프로젝트 로컬에 설치된 패키지의 실행 커맨드를 사용하려면, 

  • package,json의 npm script에명령어를 추가하여 사용해야 했다.
  • npx로 바로 실행 가능

 

전역으로 실행하고 싶은 패키지가 있을 경우,

  • npm i -g 를 이용해 전역에 꼭 설치해서 사용해야 가능했다.
  • npx로 최신버전의 패키지를 받아 바로 실행 가능

 

eject  : 바벨 웹팩 css loader 등등이 튀어나옴

 

 

npm install serve -g
serve -s build

serve라는 패키지를 전역으로 설치

serve명령어를 -s옵션으로 build폴더를 지정하여 실행

 -s 옵션(s는 single page application의 약자)은 어떤 라우팅으로 요청해도 index.html을 응답하도록 한다.

 

 

 

webpack

 

번들러 - 묶어서 주는 애 

 

js

jsx --> babel-loader

css -> css-loader

img -> file-loader

 

 Webpack :파일 확장자에 맞는 loader에게 위임

결국 웹펙은 모듈 번들러로써 최종 배포용 파일이 나옴.

 

** 우리가 git에 소스코드를 올리고 다른데서 소스코드를 받아서 똑같이 사용하기 전에

npm i를 친다. 근데 여기서 문제! 

이전과 버전정보가 다른 것이 생길 수가 있기 때문에 완벽하게 환경이 동일할 수 없다.

그래서 yarn이 나왔과 yarn에는 yarn.lock 에서 그 처리를 할 수 있었다.

npm에서 yarn을보고 package-lock.json을 만들었다.

 

 

 

ESLint

코딩 스타일 가이드를 따르지 않거나 문제가 있는 코드나 안티 패턴을 찾기 위해 사용하는 Javascript linter

올바른 코딩 습관을 위해 사용할 수 있는 툴

보통 vscode에서 extension에서 지원

 

Prettier 

예시 ) 쌍따옴표 , 홑따옴표 바꾸기 

보통 vscode에서 extension에서 지원

 

Husky

git hooks made easy

 - commit하기전에 뭘해라 push하기전에 뭘해라

 

lint-staged

Run linters on git staged files

 

 

 

React concept

Shadow DOM : 자기만의 스코프를 가지는 DOM 

Virtual DOM : DOM을 직접 다루지 않겠다.

 

** SVELTE(스벨트) : react와 반대되는 라이브러리 (virtual DOM 사용하지않음)

 

 

CSR (client side rendering)

server sending response to browser -> browser downloads JS

  -> browser executes React -> page now Viewable and Interacable

마지막 단계전까지 화면에 보여지지가 않고 로딩중

 

SSR (server side rendering)

CSR과 다르게 미리 보여짐

Server sending ready to be rendered HTML Response to browser

-> Browser Renders the page. Now Viewable and browser downloads JS

-> Browser executes React -> page  now Interactable

 

SSR이 항상 필요한게 아니고, 사용자들의 요청에 의해서 SSR이 필요한 상황이면 한다.

 

 

React DOM

만들어진 리액트 컴포넌트를 실제 DOM에 연결할때 ReactDOM을 이용

 

 

 

JSX

 

JSX문법으로 작성된 코드는 순수한 JavaScript 로 컴파일하여 사용한다. ( 누가? babel이)

왜JSX쓰나?

가독성이 좋아서, babel과 같은 컴파일 과정에서 문법적 오류를 미리 인지 가능

 

 

 

Props State

 

Props는 컴포넌트 외부에서 컴포넌트에게 주는 데이터

State는 컴포넌트 내부에서 변경할 수 있는 데이터

둘 다 변경이 발생하면, render가 발생 할 수 있다.

 

this.setState가 나온 이유 : 모든 할당문에 렌더링을 하게하면 이라기보단 setState라는 명시적인 것을 활용해서 이럴떄만 렌더링 해 라고 편하게 하기위해

 

 

 

 

 

 

 

 

 

 

 

 

 

 

반응형