Conditional-rendering, 삼항연산자, optional chaining

김루루룽·2022년 3월 22일
0

React, Next.js

목록 보기
4/42
post-thumbnail

Conditional-rendering

조건부 렌더링 :
React에서는 원하는 동작을 캡슐화하는 컴포넌트를 만들 수 있다.
애플리케이션의 상태에 따라서 컴포넌트 중 몇개 만을 렌더링 할 수 있다.

  • if나 조건부 연산자와 같은 JavaScript 연산자를 현재 상태를 나타내는 엘리먼트를 만드는데 사용.
    그러면 React는 현재 상태에 맞게 UI를 업데이트 해준다.
function Greeting(props) {
  const isLoggedIn = props.isLoggedIn;
  if (isLoggedIn) {
    return <UserGreeting />;
  }
  return <GuestGreeting />;
}

ReactDOM.render(
  // Try changing to isLoggedIn={true}:
  <Greeting isLoggedIn={false} />,
  document.getElementById('root')
);

로그인이 되었다면 유저그리팅을 렌더링하고
아니라면 게스트 그리팅을 렌더링한다.

function LoginButton(props) {
  return (
    <button onClick={props.onClick}>
      Login
    </button>
  );
}

function LogoutButton(props) {
  return (
    <button onClick={props.onClick}>
      Logout
    </button>
  );
}

로그인 로그아웃 버튼은 똑같은 위치 똑같은 구조를 사용한다고 가정한다면

  render() {
    const isLoggedIn = this.state.isLoggedIn;
    let button;
    if (isLoggedIn) {
      button = <LogoutButton onClick={this.handleLogoutClick} />;
    } else {
      button = <LoginButton onClick={this.handleLoginClick} />;
    }
    
    return (
    <div>
       <Greeting isLoggedIn={isLoggedIn} />
       {button}
    </div>
    );

렌더링을 할때 조건문을 사용해서 저렇게 표현 할 수도 있다.


변수를 선언하고 if를 사용해서 조건부로 렌더링 하는 것은 좋은 방법이지만 더 짧은 구문을 사용할 ㅅ후 있다
JSX안에서 인라인(inline)으로 처리할 방법 몇 가지가 있다.

  • 논리 &&연산자로 if를 인라인으로 표현하기
  return (
    <div>
      <h1>Hello!</h1>
      {unreadMessages.length > 0 &&
        <h2>
          You have {unreadMessages.length} unread messages.
        </h2>
      }
    </div>
  );

true && expression 은 뒤의 조건이 true일 때 출력된다.

만약 falsy한 표현을 준다면 ?

 const count = 0;
  return (
    <div>
      { count && <h1>Messages: {count}</h1>}
    </div>
  );

false면 React는 무시하고 건너 뛴다.
falsy한 표현식을 반환하면 (example 0)표현식은 건너뛰지만,
falsy 표현식이 반환된다는 것에 주의해라.
위의 예문은

0
이 render 메서드에서 반환한다.

삼항연산자

  • 조건부 연산자로 if else 구문 인라인으로 표현하기
    (삼항연산자)
    condition ? true : false
  const isLoggedIn = this.state.isLoggedIn;
  return (
    <div>
      The user is <b>{isLoggedIn ? 'currently' : 'not'}</b> logged in.
    </div>
  );
}

로그인이 되어있다면 currently를, 아니면 not을 반환한다.
출처 : React

optional chaining

optional chanining 연산자(?.)는 체인의 각 참조가 유효한지 명시적으로 검증하지 않고,
연결된 객체 체인 내에 깊숙이 위치한 속성 값을 읽을 수 있다.

옵셔널 체이닝 연산자는 .체이닝 연산자와 유사하게 작동하지만,
만약 참조가 nullish(null or undefined)라면 에러가 발생하는 것 대신에 표현식의 리턴 값은 undefined으로 단락된다.
함수 호출에서 사용될 때, 만약 주어진 함수가 없다면 undefined를 리턴한다.

let nestedProp = obj.first && obj.first.second;

let nestedProp = obj.first?.second;

optional chaining 연산자(?.)를 사용하여,
obj.first.second 에 접근하기 전에
obj.first의 상태에 따라 명시적으로 테스트하거나 단락시키지 않아도 된다.

출처 : mozilla

profile
1day 1push..plz

0개의 댓글