条件渲染

React 中的条件渲染就和在 JavaScript 中的条件语句一样。使用 JavaScript 操作符如 if  或者 条件操作符 来创建渲染当前状态的元素,并且让 React 更新匹配的 UI 。

import React, { Component } from 'react';

export default class App extends Component {
    state={
        islogin:false,
    }
    render() {
        const {islogin}=this.state;
        if(islogin){
            return <h3>Welcome!</h3>
        }
        else{
            return <h3>please login</h3>
        }
       
    }
}

使用逻辑 && 操作符的内联 if 用法

import React, { Component } from 'react';

export default class App extends Component {
    render() {
        const message = ['React','Vue','Angular','Javascript']
        return (
            <div>
                <h1>Hello!</h1>
                {message.length > 0 && 
                   <h3>You have {message.length} unread message.</h3>
                } 
            </div>
        )
       
    }
}

 在 JavaScript 中, true && expression 总是会评估为 expression ,而 false && expression 总是执行为 false 。

 因此,如果条件为 true ,则 && 后面的元素将显示在输出中。 如果是 false,React 将会忽略并跳过它。

使用条件操作符的内联 If-Else

另一个用于条件渲染元素的内联方法是使用 JavaScript 的条件操作符  condition ? true : false

import React, { Component } from 'react';

export default class App extends Component {
    state={
        islogin:false,
    }
    render() {
        const {islogin}=this.state
        return (
            <div>
               <h3>The user {islogin? 'has':'has not'} login </h3>
            </div>
        )
       
    }
}

防止组件渲染

在少数情况下,可能希望组件隐藏自身,即使它是另一个组件渲染的,为此,返回 null 而不是返回其渲染输出

 

 上面的例子中,根据 warn 的 prop 值,控制<Warning /> 组件的显示和隐藏。如果 prop 值为 false, 则 <Warning /> 组件返回 null ,不渲染。。

从组件的 render 方法返回 null 不会影响组件生命周期方法的触发。

 

 

 

 

 

 

 

 

 

  

 

posted @ 2020-03-21 22:37  shanlu  阅读(423)  评论(0编辑  收藏  举报