React条件渲染实例讲解使用
我们先创建一个用于演示条件渲染的组件
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函数中定义了一个ligin变量 他用了三元运算符 这里是在判断 this.state.signIn是不是true
如果为true 则为已登录 否则 是未登录
然后 这个ligin就接受到了结果 然后我们将他插入在我们的页面元素中
运行的效果就是这样
然后我们点一下按钮
因为按钮的点击事件会改变signIn 他的条件改变了 渲染的元素就 不一样了
然后我们的条件判断也可以直接写在页面里
我们在state中再加一个list值
constructor(props){
super(props);
this.state = {
signIn: false,
list: []
}
}
我们加了一个list变量 他的值是一个空数组
然后我们在render中循环遍历这个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>
)
}
但大家或许会发现 我们的数组是没有值的啊
用户一看 你这什么都没有 是不是出问题啦?
这是我们就可以判断 如果数组是空的 给用户一个提示
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>暂无数据....</div>
}
<button onClick = { this.increase.bind(this) }>{ this.state.signIn?"取消登录":"登录" }</button>
</div>
)
}
我们这里判断this.state.list的长度大于0 我们就循环渲染 如果是0 那就展示提示 暂无数据…
我们代码运行结果如下
到此这篇关于React条件渲染的文章就介绍到这了,更多相关React条件渲染内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
免责声明:
① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。
② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341