1. ホーム
  2. reactjs

[解決済み] Reactのレンダー機能でif...else...文を使用することは可能ですか?

2022-04-21 12:39:02

質問

基本的に、私はリアクトコンポーネントを持っており、その render() 関数本体は以下の通りです。(これは私の理想のもので、現在は動作しないということです)

render(){
    return (
        <div>
            <Element1/>
            <Element2/>
            // note: code does not work here
            if (this.props.hasImage) <MyImage />
            else <OtherElement/>
        </div>
    )
}

解決方法は?

その通りではありませんが、回避策はあります。の中にセクションがあります。 Reactのドキュメント 条件付きレンダリングについて、一度ご覧になってみてください。ここでは、インラインのif-elseを使用してできることの例を示します。

render() {
  const isLoggedIn = this.state.isLoggedIn;
  return (
    <div>
      {isLoggedIn ? (
        <LogoutButton onClick={this.handleLogoutClick} />
      ) : (
        <LoginButton onClick={this.handleLoginClick} />
      )}
    </div>
  );
}

また、render 関数の内部で、jsx を返す前に処理することもできます。

if (isLoggedIn) {
  button = <LogoutButton onClick={this.handleLogoutClick} />;
} else {
  button = <LoginButton onClick={this.handleLoginClick} />;
}

return (
  <div>
    <Greeting isLoggedIn={isLoggedIn} />
    {button}
  </div>
);

また、ZekeDroidがコメントで提起したことにも触れておく必要があります。ある条件をチェックするだけで、準拠しない特定のコードをレンダリングしたくない場合は && operator .

  return (
    <div>
      <h1>Hello!</h1>
      {unreadMessages.length > 0 &&
        <h2>
          You have {unreadMessages.length} unread messages.
        </h2>
      }
    </div>
  );