React 学习(五) ---- 条件和列表渲染
条件渲染
React中的条件渲染和我们平常写的js 代码一样,都是用的if else, 只不过在if else 中它的返回值是jsx, 根据不同的条件渲染不同的UI. 先写两个组件
//登录的用户显示欢迎
function UserWelcome(){
return <h1>Welcome to user</h1>
}
//为登录的用户显示请登录
function GusterWelcome(){
return <h1>please sign up</h1>
}
再写一个组件进行条件判断,从而显示不同的组件
function Greeting(props){
const isLogged = props.isLogged;
// 根据条件进行判断,渲染不同的组件。
if(isLogged){
return <UserWelcome /> // 返回jsx
}else {
return <GusterWelcome/>
}
}
渲染Greeting 组件,给他一个isLogged 参数,控制显示和隐藏, isLogged参数是true or false, 可以看到页面显示不同的内容
ReactDOM.render(
<Greeting isLogged={true} />,
document.getElementById('root')
);
如果是简单的条件渲染,也可以在jsx中使用条件表达式,直接用{} 把表达式包起来,因为在jsx 中,{} 中的内容都可以进行计算。如果只有条件成立的情况下执行的内容,可以使用 && 运算符, 如果条件成立和条件不成立都要执行,那就要用 三目运算符。
比如我们只想在isLogged 为true的情况下渲染组件,false 则不显示。那么我们就要用&& 。Greeting 组件修改如下
function Greeting(props){
const isLogged = props.isLogged;
return (
<div>
{isLogged && <UserWelcome />}
</div>
)
}
注意,这时要用div 标签把条件表达式包括起来,否则会报错。再用三元运算符对于Greeting 进行修改
function Greeting(props){
const isLogged = props.isLogged;
return (
<div>
{isLogged? <UserWelcome />: <GusterWelcome />}
</div>
)
}
列表渲染
React 中的列表渲染,用的是数组的map 方法,将数组中的每一项映射成一个jsx, 然后进行返回。数组就是我们要渲染到页面中的数据, 那么经过map 方法之后返回的新数组,每一项都成了包含渲染数据的jsx, 我们再对新数组进行渲染就可以把数据渲染到页面中.
// 要渲染到页面中的数据
const numbers = [1, 2, 3, 4, 5];
// listItems 经过map方法返回的新数组,它的每一项都是jsx
const listItems = numbers.map((number) =>
<li>{number}</li>
);
ReactDOM.render(
<ul>{listItems}</ul>, // 对新数组进行渲染,就可以在页面中显示数据
document.getElementById('root')
);
我们这个list 组件封装为一个组件
function NumberList(props) {
const numbers = props.numbers;
const listItems = numbers.map((number) =>
<li>{number}</li>
);
return (
<ul>{listItems}</ul>
);
}
列表组件的调用
const numbers = [1, 2, 3, 4, 5];
ReactDOM.render(
<NumberList numbers={numbers} />,
document.getElementById('root')
);
在进行列表渲染的时候,一定要给它一个key,表示每一个列表项都是唯一的,这有利于是react 优化。Key是一个字符串,给li增加一个key
<li key={number.toString()}>
{number}
</li>
由于每一项的key值是独一无二的,所以最好的key 就是每一项上的id, 那么把我们的数组改成每一项都是对象,同时对listItems 进行修改
const numbers = [
{
id:"first",
num: 1
},
{
id: "second",
num: 2
}
]
const listItems = numbers.map((number) =>
<li key={number.id}>{number.num}</li>
);
但有的时候每一个li内容都很多,我们需要把 li 单独封装成一个组件
function ListItem(props) {
const value = props.value;
return<li>{value}</li>
}
那这时key怎么处理,key 永远跟随map方法中的函数,只有map 才能产生循环, 只有在循环内确保唯一性。
function NumberList(props) {
const numbers = props.numbers;
const listItems = numbers.map((number) =>
<ListItem key={number.id} value={number.num} />
);
return (
<ul>
{listItems}
</ul>
);
}
表单操作
表单是特殊的html 元素,因为它有自己的状态,最典型的就是输入框,用户输入,输入框中直接显示用户输入的内容,它们状态都是自保持的, 这与react 所有状态是放到组件中且只能通过setState改变状态是不相符的。这时react 通过value 和onchange 事件组合解决。表单元素的value 属性从 state 中获取,用户输入时触发onChange 事件,onChange 事件中通过setState() 来动态改变状态,使输入框中的内容实时显示用户输入的内容,input, textarea, select都是这么操作的,这里要注意的是 value 和onChange 事件要写到select 标签中, textarea 也是一样。
class FormSelection extends React.Component {
constructor(props){
super(props);
this.state = {value: 'lime'} // 设置初始状态,就是下拉列表默认选择的一项
}
handleChange = (e) => {
this.setState({value: e.target.value}) // 改变状态
}
render(){
return (
<form>
<label>
Pick your favorite La Croix flavor:
<select value={this.state.value} onChange={this.handleChange}> // value 和onChange 事件写到select标签中
<option value="grapefruit">Grapefruit</option>
<option value="lime">Lime</option>
<option value="coconut">Coconut</option>
<option value="mango">Mango</option>
</select>
</label>
</form>
)
}
}
对于一个组件中有多个input,怎样设置状态? 无论是哪一个input, 只要是一输入,它就会调用onChange 事件,setState 方法,setState 方法第一个参数,就是要设置的属性,第二个参数就是得到的用记输入的值,它不会变化,都是event.target.value. 所以这里的核心就是怎么处理要设置的属性,就是我们怎么确定是哪一个input. 这要给每一个input设置一个标识, 可以用input 的name 属性,并且它的name 属性等于它的状态, 这时用户输入的时候,我们能获取到是哪个input(event.target.name),且name 值正好等于它的状态,我们调用setState() 的时候,直接把获取到的用户的值(event.target.value) 赋值给name,就可以改变input 的状态, 和用户的输入保持同步。
class FormSelection extends React.Component {
constructor(props){
super(props);
this.state = {
isGoing: true,
numberOfGuests:2
}
}
handleInputChange = (event) => {
const target = event.target;
// 获取用户输入的值
const value = target.type === 'checkbox'? target.checked: target.value;
// 通过name 获取到用于点击的输入框,由于name的取值是状态值,同时获取到input 当前状态
const name = target.name;
// 用户输入的值赋值给 name, 同时改变了input的状态
this.setState({[name]: value})
}
render(){
// 对于有两个input,给每一个input name值,唯一标识,且取值为状态值,同时保存当前状态
return (
<form>
<label>
Is going: <input name='isGoing' type="checkbox" checked= {this.state.isGoing}
onChange= {this.handleInputChange} />
</label>
<br />
<label>
Number of Guests:
<input name='numberOfGuests' type='number' value={this.state.numberOfGuests}
onChange={this.handleInputChange} />
</label>
</form>
)
}
}
ReactDOM.render(
<FormSelection />,
document.getElementById('root')
);
React 学习(五) ---- 条件和列表渲染的更多相关文章
- Vue学习(五):列表渲染
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 【vue2】Style和Class,条件,列表渲染,双向数据绑定,事件处理
目录 1.style和class 2. 条件渲染 2.1 指令 2.2 案例 3. 列表渲染 3.1 v-for:放在标签上,可以循环显示多个此标签 3.2 v-for 循环数组,循环字符串,数字,对 ...
- react学习(二)--元素渲染
元素用来描述你在屏幕上看到的内容: const element = <h1>Hello, world</h1>; 与浏览器的 DOM 元素不同,React 当中的元素事实上是普 ...
- react 入坑笔记(五) - 条件渲染和列表渲染
条件渲染和列表渲染 一.条件渲染 条件渲染较简单,使用 JavaScript 操作符 if 或条件运算符来创建表示当前状态的元素,然后让 React 根据它们来更新 UI. 贴一个小栗子: funct ...
- vue学习笔记(五)条件渲染和列表渲染
前言 在众多的编程语言中,我们的基础语法总是少不了一些专业语法,比如像定义变量,条件语句,for循环,数组,函数等等,vue.js这个优秀的前端框架中也有同样的语法,我们换一个名词,将条件语句改成专业 ...
- 前端MVC Vue2学习总结(四)——条件渲染、列表渲染、事件处理器
一.条件渲染 1.1.v-if 在字符串模板中,如 Handlebars ,我们得像这样写一个条件块: <!-- Handlebars 模板 --> {{#if ok}} <h1&g ...
- angular,vue,react的基本语法—双向数据绑定、条件渲染、列表渲染、angular小案例
基本语法: 1.双向数据绑定 vue 指令:v-model="msg" react constructor(){ this.state{ msg:"双向数据绑定" ...
- React学习笔记(七)条件渲染
React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...
- react 也就这么回事 02 —— JSX 插值表达式、条件渲染以及列表渲染
我们已经学会了 React 创建元素和渲染元素 ReactDOM.render(<div>Hello React!</div>, document.getElementById ...
随机推荐
- 使用sql语句比较excel中数据的不同
使用sql语句比较excel中数据的不同 我所在的项目组是一套物流系统,负责与公司的电商系统进行对接.但是公司的电商系统的省市区的配置和物流系统的省市区的配置有差异,所以需要找到这些差异. 首先找到我 ...
- WCF无.SVC文件服务激活,及不添加服务引用调用WCF
一,新建WCF服务引用程序 1,删除.svc文件,全部删除. 2,新建 IService 类 namespace TestWcf { [ServiceContract] public interfac ...
- HTML5事件
Html5事件 contextmenu事件 用以表示何时应该显示上下文菜单,以便开发人员取消默认的上下文菜单而提供自定义的菜单. 由于此事件时冒泡的,因此可以为document指定一个事件处理程序,用 ...
- 分享一个公众号h5裂变吸粉源码工具
这次我是分享我本人制作的一个恶搞程序,说白了就是一个公众号裂变吸粉工具,市面上有很多引流方法,例如最常见的就是色流,哈哈,今天我跟大家分享的方法是有趣的,好玩的,恶搞的.这个程序上线一天已经收获了61 ...
- kafka环境搭建和使用(python API)
引言 上一篇文章了解了kafka的重要组件zookeeper,用来保存broker.consumer等相关信息,做到平滑扩展.这篇文章就实际操作部署下kafka,用几个简单的例子加深对kafka的理解 ...
- 朱晔的互联网架构实践心得S1E6:给飞机换引擎和安全意识十原则
朱晔的互联网架构实践心得S1E6:给飞机换引擎和安全意识十原则 [下载本文PDF进行阅读] 本文有两个部分,先介绍一下给飞机换引擎这个事情我的一些经验,因为篇幅较短然后介绍一下安全意识方面的一些心得. ...
- Linux查看端口
1.lsof -i:端口号 用于查看某一端口的占用情况,比如查看8000端口使用情况,lsof -i:8000 2.netstat -tunlp |grep 端口号 用于查看指定的端口号的进程情况 ...
- 周末时间学习Linux
大家都是如何度过周末时光的呢?好多人都认为一周的工作后要好好休息下,于是在家疯狂的补觉,刷剧,打游戏,自我觉得很是正常,工作几天了,休息下不是当然嘛.是的,休息下很正常,但是把周末的时光都用到这些东西 ...
- 在k-means或kNN,我们是用欧氏距离来计算最近的邻居之间的距离。为什么不用曼哈顿距离?
曼哈顿距离只计算水平或垂直距离,有维度的限制.另一方面,欧氏距离可用于任何空间的距离计算问题. 因为,数据点可以存在于任何空间,欧氏距离是更可行的选择.例如:想象一下国际象棋棋盘,象或车所 做的移动是 ...
- Mysql 索引问题集锦
一.Mysql 中的索引 索引:顾名思义用来检索.查找数据的key (字段) 几种Mysql 中的常见索引分类:普通索引(联合索引).唯一索引.主键索引.全文索引 优点:使得查询数据变快 缺点:更新数 ...