패스트캠퍼스

2020년 1월 13일 수업 - GraphQL 2번째

sunnykim91 2020. 1. 13. 17:02
import React, 
{ 
  useState, 
  useEffect,
  useRef 
} from 'react';
// ver. 1
function Game() {
  console.log('1. load');
  const [pick, setPick] = useState('');
  const [myPick, setMyPick] = useState('');
  const [winner, setWinner] = useState('');
  const selRef = useRef(null); // ver. 2
  const runGame = val => {
    const items = ['가위', '바위', '보'];
    const ranIdx = Math.floor(Math.random() * items.length);
    setPick(items[ranIdx]);
    setMyPick(val);
  };
  useEffect(() => {
    console.log('3. useEffect1')
    let _winner;
    if (pick === '가위') {
      if (myPick === '가위') _winner = 'none';
      if (myPick === '바위') _winner = 'you';
      if (myPick === '보') _winner = 'com';
    } else if (pick === '바위') {
      if (myPick === '가위') _winner = 'com';
      if (myPick === '바위') _winner = 'none';
      if (myPick === '보') _winner = 'you';
    } else {
      if (myPick === '가위') _winner = 'you';
      if (myPick === '바위') _winner = 'com';
      if (myPick === '보') _winner = 'none';
    }
    setWinner(_winner);  // 해당 사이클에서 _winner가 바뀌지 않는다. 다음 사이클 시작 전에 바뀜
    setWinner(_winner);
    setWinner(_winner);
  }, [pick, myPick]);
  useEffect(() => {
    console.log('4. useEffect2')
    // console.log('winner is ' + winner);
  }, [winner]);
  // ver.1
  // return (
  //   <>
  //     <button onClick={() => runGame('가위')}>가위</button>
  //     <button onClick={() => runGame('바위')}>바위</button>
  //     <button onClick={() => runGame('보')}>보</button>
  //   </>
  // );
  const handleSelChange = () => {
    const val = selRef.current.value;
    // runGame(val);
    console.log(val);
  }
  // 1 2 3 4 1 2
  // ver. 2
  return (
    <>
      {winner}
      {(() => console.log('2. render'))()}
      <select ref={selRef} onChange={handleSelChange}>
        <option value="가위">가위</option>
        <option value="바위">바위</option>
        <option value="보">보</option>
      </select>
    </>
  );
}
export default Game;

react의 중요한 특징 중 하나

useEffect안의 setWinner가 순차적으로 일단 다 실행이 됨. 쭈욱 위에서 아래로

근데 state가 바뀌는것은 해당 사이클에 바뀌는것이아니라 다음 사이클 즉 load가 다시 시작될때 바뀌는 것이다.

 

 

 

 

GraphQL

 

mutation이란 타이틀(키워드)은 생략이 불가능하다. (query는 생략가능)

 

GraphQL의 list는 javascript의 배열과 동일하다. [](대괄호) 안에 써있는 부분

 

myField: [String!]

list 자체가 null인것은 상관없지만, list안에 포함되어있는 데이터는 null이 포함되면 안된다.

 

 

Interface에서 상속받은 애의 정의된 필드명은 반드시 일치시켜야하지만, 

필드값은 반드시 일치시킬필요없다. 

 

 

ApolloQL 

GraphQL을 좀 더 편리하고 생산성있게 하기위해 하는 라이브러리 (Relay라는 것도 있음)

 

(Relay : facebook에서 만든 공식적인 라이브러리이지만, 많이 쓰이지 않는다. 스키마와 쿼리에 대한 제약이 많아서.)

 

graphQL

 

데이터베이스를 캐시화했다. = 사용자가 서버단에서 캐시화를 해주게되면 (원래는 데이터베이스를 조회하여 가져와야하는데 ) 불필요하게 데이터를 조회하는 과정을 생략하여 한 번 가져왔던 데이터를 저장했다가 이것을 불러오게된다.

 

 

VisualStudio setting

npm i apollo-client apollo-cache-inmemory apollo-link-http graphql graphql-tag react-apollo

이렇게 설치한다. 

 

Apollo Boost :  apollo client, cache-inmemory 등을 포함하고 있음.

보통 패키지단위로 설치를 하긴하지만, 많은 패키지를 설치를 하면 성능에 좋지 않으므로

필요한것 즉 apollo client와 inmemory정도 설치한다.

 

 

** 항상 동일한 쿼리를 요청 => 캐시

graphQL : 기존의 REST API 를 해결하기 위해 사용 , 페이스북에서 만든 쿼리 언어

gql은 웹 클라이언트가 데이터를 서버로 부터 효율적으로 가져오는 것이 목적

 

Rest API와 비교하였을때

REST API는 URL, METHOD등을 조합하기 때문에 다양한 Endpoint가 존재 합니다. 반면, gql은 단 하나의 Endpoint가 존재 합니다. 또한, gql API에서는 불러오는 데이터의 종류를 쿼리 조합을 통해서 결정 합니다. 예를 들면, REST API에서는 각 Endpoint마다 데이터베이스 SQL 쿼리가 달라지는 반면, gql API는 gql 스키마의 타입마다 데이터베이스 SQL 쿼리가 달라집니다.

(https://tech.kakao.com/2019/08/01/graphql-basic/ 에서 가져왔습니다.)

 

 

 

 

반응형