Reactレンダリング関数でif…else…ステートメントを使用することは可能ですか?


101

基本的に、私はreactコンポーネントを持っており、そのrender()関数本体は次のとおりです:(これは私の理想的なコンポーネントです。つまり、現在は機能しません)

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

ええ、これは遭遇する非常に一般的な問題であり、素晴らしい質問です!少し違う言い方をして、この特定のコードを実行するとどうなるかを示すと(少しフォーマットすることも検討してください)、問題を正確に解決するのに役立つかもしれません。
ZekeDroid 2016年

はい、それは間違ったものです(理想的なもの)。問題を解決するために質問を更新しました。ありがとう
Xin

1
...それ以外の場合はレンダリングできません
vijay 2017年

回答:


193

正確にはそのようではありませんが、回避策があります。Reactのドキュメントには、条件付きレンダリングに関するセクションがあり、確認する必要があります。これは、インラインif-elseを使用して実行できることの例です。

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

レンダリング関数内で、ただし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>
  );

15
気の利いたトリックもJSの短絡機能を使用しています!isTrue ? <div>Something</div> : nullあなたができるようなことをするのを避けるためにisTrue && <div>Something</div>
ZekeDroid 2016年

1
さらに、次の記事をチェックアウトして、他の場合とは別に、Reactでのより多くの条件付きレンダリングについて調べることができます。
Robin Wieruch 2017年

「data.map(item =>(<tr> <td> if(item.type == 'image'){<image src = "{image.src}">}」のように、ループ内の条件を処理したい{{item}} </ td> </ tr>)) "このようなもの
Vikas Chauhan 2018年

55

OPが求めていることを正確に行う方法が実際にあります。次のように無名関数をレンダリングして呼び出すだけです。

render () {
  return (
    <div>
      {(() => {
        if (someCase) {
          return (
            <div>someCase</div>
          )
        } else if (otherCase) {
          return (
            <div>otherCase</div>
          )
        } else {
          return (
            <div>catch all</div>
          )
        }
      })()}
    </div>
  )
}

6

、:のconditionalようなステートメントを使用して、何でもレンダリングできます。ifelse

 render() {
    const price = this.state.price;
    let comp;

    if (price) {

      comp = <h1>Block for getting started with {this.state.price}</h1>

    } else {

      comp = <h1>Block for getting started.</h1>

    }

    return (
      <div>
        <div className="gettingStart">
          {comp}
        </div>
      </div>
    );
  }

5

項演算子について覚えておく必要があります

したがって、コードは次のようになります。

render(){
    return (
        <div>
            <Element1/>
            <Element2/>
            // note: code does not work here
            { 
               this.props.hasImage ?  // if has image
               <MyImage />            // return My image tag 
               :
               <OtherElement/>        // otherwise return other element  

             }
        </div>
    )
}

4

条件に要素を表示したい場合は、次のようなものを使用できます。

renderButton() {
    if (this.state.loading) {
        return <Spinner size="small" spinnerStyle={styles.spinnerStyle} />;
    }

    return (
        <Button onPress={this.onButtonPress.bind(this)}>
            Log In
        </Button>
    );
}

次に、render関数内のhelpingメソッドを呼び出します。

<View style={styles.buttonStyle}>
      {this.renderButton()}
</View>

または、return内で別の条件を使用することもできます。

{this.props.hasImage ? <element1> : <element2>}

4

タイプ1: Ifステートメントスタイル

{props.hasImage &&

  <MyImage />

}


タイプ2: If elseステートメントスタイル

   {props.hasImage ?

      <MyImage /> :

      <OtherElement/>

    }

2

ifelse構造の省略形はJSXで期待どおりに機能します

this.props.hasImage ? <MyImage /> : <SomeotherElement>

あなたはこのブログ投稿の他のオプションを見つけることができDevNachoを、それは速記でそれを行うために、より一般的です。より大きなif句が必要な場合はコンポーネントAまたはコンポーネントBを返す関数を作成する必要があります。

例えば:

this.setState({overlayHovered: true});

renderComponentByState({overlayHovered}){
    if(overlayHovered) {
        return <overlayHoveredComponent />
    }else{
        return <overlayNotHoveredComponent />
    }
}

パラメータとして指定すると、overlayHoveredをthis.stateから分解できます。次に、render()メソッドでその関数を実行します。

renderComponentByState(this.state)


2

複数の条件が必要な場合は、これを試すことができます

https://www.npmjs.com/package/react-if-elseif-else-render

import { If, Then, ElseIf, Else } from 'react-if-elseif-else-render';

class Example extends Component {

  render() {
    var i = 3; // it will render '<p>Else</p>'
    return (
      <If condition={i == 1}>
        <Then>
          <p>Then: 1</p>
        </Then>
        <ElseIf condition={i == 2}>
          <p>ElseIf: 2</p>
        </ElseIf>
        <Else>
          <p>Else</p>
        </Else>
      </If>
    );
  }
}

1

ここでは遅すぎるかもしれません。しかし、これが誰かを助けることを願っています。まず、これら2つの要素を分離します。

renderLogout(){
<div>
   <LogoutButton onClick={this.handleLogoutClick} />
<div>
}

renderLogin(){
<div>
   <LoginButton onClick={this.handleLoginClick} />
<div>
}

次に、if elseステートメントを使用して、render関数からこれらの関数を呼び出すことができます。

render(){
if(this.state.result){
  return this.renderResult();
}else{
  return this.renderQuiz();
}}

これは私にとってはうまくいきます。:)



1

2つの異なる依存関係がある場合は、条件演算子内で条件(三項)演算子を使用することもできます。

{
(launch_success)
  ?
  <span className="bg-green-100">
    Success
  </span>
  :
  (upcoming)
    ?
    <span className="bg-teal-100">
      Upcoming
    </span>
    :
    <span className="bg-red-100">
      Failed
    </span>
}

1

Switchケースまたは三項演算子を使用してみてください

render(){
    return (
        <div>
            <Element1/>
            <Element2/>
            // updated code works here
            {(() => {
                        switch (this.props.hasImage) {
                            case (this.props.hasImage):
                                return <MyImage />;
                            default:
                                return (
                                   <OtherElement/>; 
                                );
                        }
                    })()}
        </div>
    )
}

これは私にとってはうまくいき、他の人にとってもうまくいくはずです。三項演算子を試す

弊社のサイトを使用することにより、あなたは弊社のクッキーポリシーおよびプライバシーポリシーを読み、理解したものとみなされます。
Licensed under cc by-sa 3.0 with attribution required.