React條件渲染實例講解使用
我們先創(chuàng)建一個用于演示條件渲染的組件
import './App.css'; import React from "react"; class App extends React.Component{ constructor(props){ super(props); this.state = { signIn: false } } increase(){ this.setState({ signIn: !this.state.signIn }) } render(){ let ligin = this.state.signIn?<span>已登錄</span>:<span>未登錄</span> return ( <div className="App"> { ligin } <button onClick = { this.increase.bind(this) }>{ this.state.signIn?"取消登錄":"登錄" }</button> </div> ) } } export default App;
這里我們模擬了一個登錄和未登錄的情況
首先 我們在state中定義了一個signIn 這是個布爾類型的變量 比喻成 他為true 表示用戶已登錄 為false 表示用戶還沒有登錄
然后 我們在render函數(shù)中定義了一個ligin變量 他用了三元運算符 這里是在判斷 this.state.signIn是不是true
如果為true 則為已登錄 否則 是未登錄
然后 這個ligin就接受到了結(jié)果 然后我們將他插入在我們的頁面元素中
運行的效果就是這樣
然后我們點一下按鈕
因為按鈕的點擊事件會改變signIn 他的條件改變了 渲染的元素就 不一樣了
然后我們的條件判斷也可以直接寫在頁面里
我們在state中再加一個list值
constructor(props){ super(props); this.state = { signIn: false, list: [] } }
我們加了一個list變量 他的值是一個空數(shù)組
然后我們在render中循環(huán)遍歷這個list
render(){ let ligin = this.state.signIn?<span>已登錄</span>:<span>未登錄</span> return ( <div className="App"> { ligin } <div> { this.state.list.map((item,index) =>{ return <p key = {index}>{ item }</p> }) } </div> <button onClick = { this.increase.bind(this) }>{ this.state.signIn?"取消登錄":"登錄" }</button> </div> ) }
但大家或許會發(fā)現(xiàn) 我們的數(shù)組是沒有值的啊
用戶一看 你這什么都沒有 是不是出問題啦?
這是我們就可以判斷 如果數(shù)組是空的 給用戶一個提示
render(){ let ligin = this.state.signIn?<span>已登錄</span>:<span>未登錄</span> return ( <div className="App"> { ligin } { this.state.list.length > 0? <div> { this.state.list.map((item,index) =>{ return <p key = {index}>{ item }</p> }) } </div> : <div>暫無數(shù)據(jù)....</div> } <button onClick = { this.increase.bind(this) }>{ this.state.signIn?"取消登錄":"登錄" }</button> </div> ) }
我們這里判斷this.state.list的長度大于0 我們就循環(huán)渲染 如果是0 那就展示提示 暫無數(shù)據(jù)…
我們代碼運行結(jié)果如下
到此這篇關(guān)于React條件渲染的文章就介紹到這了,更多相關(guān)React條件渲染內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
React-Native使用Mobx實現(xiàn)購物車功能
本篇文章主要介紹了React-Native使用Mobx實現(xiàn)購物車功能,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-09-09react-redux中connect的裝飾器用法@connect詳解
這篇文章主要介紹了react-redux中connect的裝飾器用法@connect詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-01-01react-native-fs實現(xiàn)文件下載、文本存儲的示例代碼
本篇文章主要介紹了react-native-fs實現(xiàn)文件下載、文本存儲的示例代碼,具有一定的參考價值,有興趣的可以了解下2017-09-09React Native自定義標題欄組件的實現(xiàn)方法
今天講一下如何實現(xiàn)自定義標題欄組件,我們都知道RN有一個優(yōu)點就是可以組件化,在需要使用該組件的地方直接引用并傳遞一些參數(shù)就可以了,這種方式確實提高了開發(fā)效率。對React Native自定義標題欄組件的實現(xiàn)方法感興趣的朋友參考下2017-01-01React使用useImperativeHandle自定義暴露給父組件的示例詳解
useImperativeHandle?是?React?提供的一個自定義?Hook,用于在函數(shù)組件中顯式地暴露給父組件特定實例的方法,本文將介紹?useImperativeHandle的基本用法、常見應用場景,需要的可以參考下2024-03-03