조건부 렌더링 :
React에서는 원하는 동작을 캡슐화하는 컴포넌트를 만들 수 있다.
애플리케이션의 상태에 따라서 컴포넌트 중 몇개 만을 렌더링 할 수 있다.
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)으로 처리할 방법 몇 가지가 있다.
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 표현식이 반환된다는 것에 주의해라.
위의 예문은
const isLoggedIn = this.state.isLoggedIn;
return (
<div>
The user is <b>{isLoggedIn ? 'currently' : 'not'}</b> logged in.
</div>
);
}
로그인이 되어있다면 currently를, 아니면 not을 반환한다.
출처 : React
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