25-React事件处理及条件渲染
Handling Events
React元素的事件处理非常类似于对DOM元素添加事件处理,但有一部分的语法不同:
1.React事件使用camelCase(驼峰命名法)来进行命名,而不是小写字母
2.JSX需要传递一个函数作为事件处理函数,而不是一个字符串。
//DOM元素的事件处理函数
<button onclick="activateLaser()">
Activate Lasers
</button>
//React元素的事件处理函数
<button onClick={activateLasers} >
Activate Lasers
</button>
3.不能够通过返回一个false来阻止默认操作。必须调用preventDefault
//DOM元素事件处理阻止默认操作
<a href="#" onclick="console.log('The link was clicked.'); return false;">
Click me
</a>
//React元素
function ActionLink() {
//e是事件的各种信息,是根据W3C标准定义的。不需要考虑浏览器兼容问题
function handleClick(e) {
e.preventDefault();
console.log('The link was clicked.');
}
return (
<a href="#" onClick={handleClick}>
Click me
</a>
)
}
4.在JSX的回调函数中,要注意this的含义,JavaScript中,类方法并不属于任何运行形式,所以如果忘记绑定类的this给事件处理函数的话,那么this在事件处理函数中会变成undefined。如果你不带()来调用一个方法的时候,必须要绑定类的this给事件处理函数。如果这样很麻烦的话,可以使用箭头运算符来定义方法。或者使用箭头运算符来进行回调函数调用。
Conditional Rendering
1.在React中,你可以创建不同的组件,并且渲染其中的一部分,这取决于你应用的状态。状态渲染和JavaScript中的分支运算符有一样的效果,使用JavaScript中的类似if运算符来创建元素来代表当前状态,然后让React更新UI去匹配。
if(this.state.isLogin){
return(
<div>
<Greeting></Greeting>
<button onClick={this.changeState}>修改状态</button>
</div>)
}else{
return(
<div>
<Login></Login>
<button onClick={this.changeState}>修改状态</button>
</div>)
}
2.元素变量可以使用变量来存储元素,可以帮助你在保证其他部分的输出不变的情况下,选择性的渲染一部分组件。
render() {
const isLoggedIn = this.state.isLoggedIn;
let button = null; //通过if条件语句来进行渲染
if (isLoggedIn) {
button = <LogoutButton onClick={this.handleLogoutClick} />
} else {
button = <LoginButton onClick={this.handleLoginClick} />
}
return (
<div>
<Greeting isLoggedIn={isLoggedIn} />
{button}
</div>
);
}
2.使用&&运算符实现行内逻辑
根据JavaScript的语法:true && expression的值永远都是expression,而false && expression的值一直都是false。所以,如果条件表达式的结果为true,那么就会直接返回后面的值,如果结果为false则React会忽略并且跳过后面的表达式。
return (
<div>
<h1>Hello!</h1>
{ unreadMessages.length > 0 &&
<h2>
You have {unreadMessages.length} unread messages.
</h2>
}
</div>
);
3.行内if-else条件运算符另外一种实现行内渲染元素中的JavaScript条件表达式的是三目运算符condition ? true : false,下面的代码中使用了三目运算符。
render() {
const isLoggedIn = this.state.isLoggedIn;
return (
<div>
The user is <b> {isLoggedIn ? 'currently' : 'not'}</b> logged in.
</div>
);
}
4.阻止组件渲染在小部分情况下,你可能需要让一个元素隐藏。可以让render返回null而不是一个组件。
render() {
return (
<div>
<WarningBanner warn={this.state.showWarning}>
</WarningBanner>
<button onClick={this.handleToggleClick}>
{this.state.showWarning ? 'Hide' : 'Show'}
</button>
</div>
);
}
总结
从上面我们可以学到:
关于Handling Events(事件处理)JSX的语法与JS的四点不同:
1.JSX用驼峰命名事件,JS用小写字母;
2.JSX的事件处理函数语法 {函数名} ,JS为"函数名()";
3.JSX调用preventDefault()来阻止默认操作,JS则通过return false;
4.JSX的回调函数中,需要绑定类的this给事件函数,
可在初始化时绑定(this.handleLoginClick = this.handleLoginClick.bind(this);)
或在具体使用该函数的地方绑定({this.handleLoginClick.bind(this)}),
JS不用绑定(onClick="doHandle(this);"),还可以用箭头运算符来定义方法或调用回调函数。
关于Conditional Rendering 可以用变量来存储元素,然后根据流程控制语句以及逻辑运算符
来return需要的变量值,若想阻止渲染则return null。
25-React事件处理及条件渲染的更多相关文章
- 【译】在React中实现条件渲染的7种方法
原文地址:https://scotch.io/tutorials/7-ways-to-implement-conditional-rendering-in-react-applications 借助R ...
- React 学习(五) ---- 条件和列表渲染
条件渲染 React中的条件渲染和我们平常写的js 代码一样,都是用的if else, 只不过在if else 中它的返回值是jsx, 根据不同的条件渲染不同的UI. 先写两个组件 //登录的用户显示 ...
- react初探(一)之JSX、状态(state)管理、条件渲染、事件处理
前言: 最近收到组长通知我们项目组后面新开的项目准备统一技术栈为react,目前我的情况是三大框架只会angular和Vue.在实际项目中只使用过一次angular5,其余项目都是使用Vue写的.写篇 ...
- &&运算符,三木运算符与React的条件渲染
在使用react框架的时候中往往会遇到需要条件渲染的情形,这时候,许多人会设想采用if语句来实现,比如下面,当满足条件condition时,conditonRender渲染组件ComponentA,当 ...
- react 入坑笔记(五) - 条件渲染和列表渲染
条件渲染和列表渲染 一.条件渲染 条件渲染较简单,使用 JavaScript 操作符 if 或条件运算符来创建表示当前状态的元素,然后让 React 根据它们来更新 UI. 贴一个小栗子: funct ...
- angular,vue,react的基本语法—双向数据绑定、条件渲染、列表渲染、angular小案例
基本语法: 1.双向数据绑定 vue 指令:v-model="msg" react constructor(){ this.state{ msg:"双向数据绑定" ...
- React文档(八)条件渲染
在React中,你可以创建不同的组件各自封装你需要的东西.之后你可以只渲染其中的一部分,这取决于应用的state(状态). 条件渲染在React里就和js里的条件语句一样.使用js里的if或者条件表达 ...
- 2017.11.7 ant design - upload 组件的使用, react 条件渲染以及 axios.all() 的使用
一.主要任务:悉尼小程序管理后台,添加景点页面的开发 二.所遇问题及解决 1. 上传多个不同分类音频信息时,如中文音频和英文音频,要求音频不是放在一个数组中的,每个音频是一个独立的字段,此时: < ...
- React学习笔记(七)条件渲染
React学习笔记(七) 六.条件渲染 使用if或条件运算符来创建表示当前状态的元素. 可以使用变量来存储元素.比如: let button = null; if (isLoggedIn) { but ...
随机推荐
- (第九周)视频发布及git统计报告
项目名:食物链教学工具 组名:奋斗吧兄弟 组长:黄兴 组员:李俞寰.杜桥.栾骄阳.王东涵 代码地址:HTTPS: https://git.coding.net/li_yuhuan/FoodChain. ...
- [php] 使用IDE的正则搜索代码
([^a-zA-Z_=$0-9/\[\>])('|"|,)?(\s*)store_banner(\s*)('|"|,)?([^a-zA-Z_=$0-9\/\(\]:]) 用在 ...
- VMware搭建 sql server2012集群加节点 KB953748
--node4加入节点前 将共享磁盘挂载到node4,仅测试验证磁盘挂载,否则会导致整个集群磁盘offline切换 --node4 加入集群报错,无法访问计算机“node4” 0.public网卡勾选 ...
- zw版【转发·台湾nvp系列Delphi例程】HALCON DirectShow
zw版[转发·台湾nvp系列Delphi例程]HALCON DirectShow unit Unit1;interfaceuses Windows, Messages, SysUtils, Varia ...
- Win7旗舰版中的IIS配置asp.net的运行环境
Win7旗舰版中的IIS配置asp.net的运行环境 以前弄过好多次,都没有成功,昨天晚上不知怎么地就成功了,借用我同学的一句话,这叫“灵光一闪”,废话不多说了,这个成功是有图有视频有真相地哈! ...
- 为什么在我眼里你是一只傻逼——傻逼“常所用”句型之(2)——“当当网的就有XXX人评论,YYY%的推荐”
A:这东西里面尽是大粪. B:这东西当当网的就有325人评论,98.8%的推荐.京东的整体评论是五星,37人评价,31人给好评,1人差评,5人中评:亚马逊有6条好评,1条中评. http://news ...
- 【海岛帝国系列赛】No.5 海岛帝国:独立之战
50229234海岛帝国:独立之战 [试题描述] 恐怖分子多年来一直如饥似渴地渴求“药师傅”帝国,但是,“里脊肉”BANNIE时刻在守护着这一方水土.从而使帝国日益强大.如今,BANNIE由于在 “牡 ...
- Maven(一)
Maven学习总结(一)——Maven入门 一.Maven的基本概念 Maven(翻译为"专家","内行")是跨平台的项目管理工具.主要服务于基于Java平台的 ...
- linux设备驱动归纳总结(五):1.在内核空间分配内存【转】
本文转载自:http://blog.chinaunix.net/uid-25014876-id-79134.html linux设备驱动归纳总结(五):1.在内核空间分配内存 xxxxxxxxxxxx ...
- 161116、springmvc自己实现防止表单重复提交(基于注解)
原理:在去某个页面直接生成一个随机数(这里使用的是UUID)并放入session中,用户提交表单时将这个随机数传入服务端与session中的值进行比较,如果不不存在或不相等,则认为是重复提交:如果相等 ...