React筆記7(條件渲染)

條件渲染

在React中,可以創(chuàng)建不同的組件來(lái)封裝各種所需要的行為浦译,也可以根據(jù)應(yīng)用的變換狀態(tài)只更新其中一部分住涉。

首先創(chuàng)建一個(gè)Gretting組件缩挑,他會(huì)根據(jù)用戶(hù)是否登錄來(lái)顯示不同的內(nèi)容。

function UserGreeting(props) {
    return <h1>Welcome back!</h1>;
}
  
function GuestGreeting(props) {
    return <h1>Please sign up.</h1>;
}

function Greeting(props){
    const isLoggedIn = props.isLoggedIn;
    if(isLoggedIn){
        return <UserGreeting />
    }else{
        return <GuestGreeting />
    }
}

ReactDOM.render(
    <Greeting isLoggedIn={false} />,
    document.getElementById('root')
)

元素變量

你可以使用變量來(lái)儲(chǔ)存元素扎即,可以用來(lái)有條件的渲染組件的一部分吞获,輸出的其他部分則不用修改。

以下的2個(gè)組件分別代表 注銷(xiāo) 和 登錄

//定義一個(gè)登錄按鈕小組件
function LoginButton(props){
    return (
        <button onClick={props.onClick}>
            Login
        </button>
    )
}
//定義一個(gè)登出按鈕小組件
function LogoutButton(props){
    return (
        <button onClick={props.onClick}>
            Logout
        </button>
    )
}

然后谚鄙,我們開(kāi)始創(chuàng)建一個(gè)LoginControl的組件
他會(huì)根據(jù)當(dāng)前狀態(tài)來(lái)渲染<LoginButton /><LogoutButton />以及顯示的<Greeting />的內(nèi)容

//登錄狀態(tài)1
function UserGreeting(props) {
    return <h1>Welcome back!</h1>;
}
 //登錄狀態(tài)2
function GuestGreeting(props) {
    return <h1>Please sign up.</h1>;
}
//條件渲染提示狀態(tài)語(yǔ)
function Greeting(props){
    const isLoggedIn = props.isLoggedIn;
    if(isLoggedIn){
        return <UserGreeting />
    }else{
        return <GuestGreeting />
    }
}
//創(chuàng)建一個(gè)按鈕登錄小組件
function LoginButton(props){
    return (
        <button onClick={props.onClick}>
            Login
        </button>
    )
}
//創(chuàng)建一個(gè)按鈕登出小組件
function LogoutButton(props){
    return (
        <button onClick={props.onClick}>
            Logout
        </button>
    )
}
//創(chuàng)建一個(gè)登錄狀態(tài)控制組件
class LoginControl extends React.Component{
    constructor(props){
        super(props);
        this.handleLoginClick = this.handleLoginClick.bind(this);
        this.handleLogoutClick = this.handleLogoutClick.bind(this);
        this.state = {isLoggedIn:false};
    }
    handleLoginClick(){
        this.setState({
            isLoggedIn:true
        })
    }
    handleLogoutClick(){
        this.setState({
            isLoggedIn:false
        })
    }
    render(){
        const isLoggedIn = this.state.isLoggedIn;
        let button = null;
        if(isLoggedIn){
            button = <LoginButton onClick={this.handleLogoutClick} />
        }else{
            button = <LogoutButton onClick={this.handleLoginClick} />
        }

        return(
            <div class="box">
                <Greeting isLoggedIn={isLoggedIn} />
                {button}
            </div>
        )
    }
}

ReactDOM.render(
    <LoginControl />,
    document.getElementById('root')
)

使用變量并且使用if語(yǔ)句各拷,是條件渲染組件不出的方式,但有時(shí)候可以使用更加簡(jiǎn)潔的方式闷营,可以使用jsx的方式

1.與運(yùn)算符&&

可以使用花括弧包裹代碼嵌入jsx中烤黍,其中包括js邏輯與&&,他能很方便的渲染一個(gè)元素

function Mailbox(props){
    const unreadMessage = props.unreadMessage;
    return(
        <div>
            <h1>hello</h1>
            {unreadMessage.length>0&&
                <h2>you have {unreadMessage.length} unread message</h2>
            }
        </div>
    )
}

const message = ['react','reactdom','redux'];
ReactDOM.render(
    <Mailbox unreadMessage={message} />,
    document.getElementById('root')
)
//返回  you have 3 unread message

之所以可以這樣做,是因?yàn)樵趈avascript中蚊荣,true&&表達(dá)式初狰,會(huì)返回表達(dá)式,而false&&表達(dá)式互例,會(huì)返回false奢入,false就會(huì)忽略跳過(guò)。

2.三目運(yùn)算符

條件如果成立媳叨,執(zhí)行do someting腥光,否則執(zhí)行冒號(hào)后語(yǔ)句
condition?'do someting':'do noting'
condition?true:false

demo有條件的渲染

//demo1
render() {
  const isLoggedIn = this.state.isLoggedIn;
  return (
    <div>
      The user is <b>{isLoggedIn ? 'currently' : 'not'}</b> logged in.
    </div>
  );
}
//demo2
render() {
  const isLoggedIn = this.state.isLoggedIn;
  return (
    <div>
      {isLoggedIn ? (
        <LogoutButton onClick={this.handleLogoutClick} />
      ) : (
        <LoginButton onClick={this.handleLoginClick} />
      )}
    </div>
  );
}

像在 JavaScript 中一樣,你可以根據(jù)團(tuán)隊(duì)的習(xí)慣選擇更易讀的方式糊秆。還要記住如果條件變得過(guò)于復(fù)雜武福,可能就是提取組件的好時(shí)機(jī)了。

3.阻止組件的渲染

在極少的情況下痘番,你可能希望隱藏組件捉片,即使其他組件會(huì)渲染該組件,讓render方法返回null汞舱,而不產(chǎn)生他的渲染結(jié)果伍纫,就可以實(shí)現(xiàn)這個(gè)需求。

在下面的例子中昂芜,<WarningBanner /> 根據(jù)屬性 warn 的值條件渲染莹规。如果warn 的值是 false,則組件不會(huì)渲染:

function WarningBanner(props){
    if(props.warn){
        return null //或者return false 此處可以停止組件渲染
    }
    return (
        <div className="warning">Warning!!!</div>
    )
}

class Page extends React.Component{
    constructor(props){
        super(props);
        this.state = {showWarning:true};
        this.handleToggleClick = this.handleToggleClick.bind(this);
    }
    handleToggleClick(){
        this.setState(prevState=>({
            showWarning:!prevState.showWarning
        }))
    }
    render(){
        return(
            <div>
                <WarningBanner warn={this.state.showWarning} />
                <button onClick={this.handleToggleClick}>
                    {this.state.showWarning?'warning的值為true':'warning的值為false'}
                </button>
            </div>
        )
    }
}

ReactDOM.render(
    <Page />,
    document.getElementById('root')
)

注意:
組件的render()方法返回null泌神,并不會(huì)影響他的生命周期方法的回調(diào)良漱,例如componentWillUpdatecomponentDidUpdate,依然可以使用。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末欢际,一起剝皮案震驚了整個(gè)濱河市母市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌幼苛,老刑警劉巖窒篱,帶你破解...
    沈念sama閱讀 219,110評(píng)論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場(chǎng)離奇詭異舶沿,居然都是意外死亡墙杯,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門(mén)括荡,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)高镐,“玉大人,你說(shuō)我怎么就攤上這事畸冲〖邓瑁” “怎么了观腊?”我有些...
    開(kāi)封第一講書(shū)人閱讀 165,474評(píng)論 0 356
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)算行。 經(jīng)常有香客問(wèn)我梧油,道長(zhǎng),這世上最難降的妖魔是什么州邢? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,881評(píng)論 1 295
  • 正文 為了忘掉前任儡陨,我火速辦了婚禮,結(jié)果婚禮上量淌,老公的妹妹穿的比我還像新娘骗村。我一直安慰自己,他們只是感情好呀枢,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評(píng)論 6 392
  • 文/花漫 我一把揭開(kāi)白布胚股。 她就那樣靜靜地躺著,像睡著了一般裙秋。 火紅的嫁衣襯著肌膚如雪琅拌。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,698評(píng)論 1 305
  • 那天摘刑,我揣著相機(jī)與錄音财忽,去河邊找鬼。 笑死泣侮,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的紧唱。 我是一名探鬼主播活尊,決...
    沈念sama閱讀 40,418評(píng)論 3 419
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼漏益!你這毒婦竟也來(lái)了蛹锰?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 39,332評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤绰疤,失蹤者是張志新(化名)和其女友劉穎铜犬,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體轻庆,經(jīng)...
    沈念sama閱讀 45,796評(píng)論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡癣猾,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評(píng)論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了余爆。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片纷宇。...
    茶點(diǎn)故事閱讀 40,110評(píng)論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蛾方,靈堂內(nèi)的尸體忽然破棺而出像捶,到底是詐尸還是另有隱情上陕,我是刑警寧澤,帶...
    沈念sama閱讀 35,792評(píng)論 5 346
  • 正文 年R本政府宣布拓春,位于F島的核電站释簿,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏硼莽。R本人自食惡果不足惜庶溶,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評(píng)論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望沉删。 院中可真熱鬧渐尿,春花似錦、人聲如沸矾瑰。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 32,003評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)殴穴。三九已至凉夯,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間采幌,已是汗流浹背劲够。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 33,130評(píng)論 1 272
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留休傍,地道東北人征绎。 一個(gè)月前我還...
    沈念sama閱讀 48,348評(píng)論 3 373
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像磨取,于是被迫代替她去往敵國(guó)和親人柿。 傳聞我的和親對(duì)象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評(píng)論 2 355

推薦閱讀更多精彩內(nèi)容

  • mean to add the formatted="false" attribute?.[ 46% 47325/...
    ProZoom閱讀 2,699評(píng)論 0 3
  • HTML模版 之后出現(xiàn)的React代碼嵌套入模版中忙厌。 1. Hello world 這段代碼將一個(gè)一級(jí)標(biāo)題插入到指...
    ryanho84閱讀 6,240評(píng)論 0 9
  • Spring Cloud為開(kāi)發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見(jiàn)模式的工具(例如配置管理凫岖,服務(wù)發(fā)現(xiàn),斷路器逢净,智...
    卡卡羅2017閱讀 134,662評(píng)論 18 139
  • 和北上廣的廣大“剩女”一樣哥放,茹迦有著普通的工作,普通的外貌爹土,普通的知識(shí)分子家庭甥雕。不同之處是,今年35歲的她着饥,依舊單...
    俞沛珈閱讀 600評(píng)論 0 0
  • 如果有如果犀农,我不會(huì)在期末熬夜點(diǎn)燈 因?yàn)?我會(huì)用如果 給我一個(gè)返回時(shí)間的偉績(jī) 我錯(cuò)了一道又一道的題 刷一個(gè)又一個(gè)知識(shí)...
    西泠橋頭_佳人閱讀 158評(píng)論 0 0