React 组件条件渲染的几种方式

一、条件表达式渲染 (适用于两个组件二选一的渲染)

复制代码

 1 render() {
 2   const isLoggedIn = this.state.isLoggedIn;
 3   return (
 4     <div>
 5       {isLoggedIn ? (
 6         <LogoutButton onClick={this.handleLogoutClick} />
 7       ) : (
 8         <LoginButton onClick={this.handleLoginClick} />
 9       )}
10     </div>
11   );
12 }

复制代码

二、&& 操作符渲染 (适用于一个组件有无的渲染)

复制代码

 1 function Mailbox(props) {
 2   const unreadMessages = props.unreadMessages;
 3   return (
 4     <div>
 5       <h1>Hello!</h1>
 6       {unreadMessages.length > 0 &&
 7         <h2>
 8           You have {unreadMessages.length} unread messages.
 9         </h2>
10       }
11     </div>
12   );
13 }

复制代码

三、利用变量输出组件渲染 (适用于有多个组件多种条件下的渲染)

复制代码

 1 render() {
 2     const isLoggedIn = this.state.isLoggedIn;
 3     
 4     const button = isLoggedIn ? (
 5       <LogoutButton onClick={this.handleLogoutClick} />
 6     ) : (
 7       <LoginButton onClick={this.handleLoginClick} />
 8     );
 9 
10     return (
11       <div>
12         <Greeting isLoggedIn={isLoggedIn} />
13         {button}
14       </div>
15     );
16   }

复制代码

四、利用函数方法输出组件或者利用函数式组件进行渲染 (适用于多个子组件需要根据复杂的条件输出的情况)

1. 函数方式

复制代码

 1 renderButton(){
 2     const isLoggedIn = this.state.isLoggedIn;
 3     if(isLoggedIn)
 4     {
 5        return (<LogoutButton onClick={this.handleLogoutClick} />);
 6     }
 7     else
 8     {
 9       return (<LoginButton onClick={this.handleLoginClick} />);
10     }
11 }
12 
13 render() {
14     return (
15       <div>
16         <Greeting />
17         {this.renderButton()}
18       </div>
19     );
20   }

复制代码

 

2. 函数式组件

复制代码

 1 function Greeting(props) {
 2   const isLoggedIn = props.isLoggedIn;
 3   if (isLoggedIn) {
 4     return <UserGreeting />;
 5   }
 6   return <GuestGreeting />;
 7 }
 8 
 9 ReactDOM.render(
10   // Try changing to isLoggedIn={true}:
11   <Greeting isLoggedIn={false} />,
12   document.getElementById('root')
13 );

复制代码

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值