React学习之JSX与react事件实例分析


Posted in Javascript onJanuary 06, 2020

本文实例讲述了React学习之JSX与react事件。分享给大家供大家参考,具体如下:

1、JSX

1.1、表达式

在React中使用JSX来描述HTML页面,而且可以与js混合使用,使用JavaScript表达式时要将表达式包含在大括号里

const user = {
 firstName: 'Harper',
 lastName: 'Perez'
};
const element = (    //将JSX语句保存在变量中
 <h1>
  Hello, {formatName(user)}!  {/* {}中写js语句*/}
 </h1>
);

在编译之后呢,JSX 其实会被转化为普通的 JavaScript 对象,可以对其赋值或把它当作参数传递:

ReactDOM.render(
 element,        //通过JSX变量渲染react节点
 document.getElementById('root')
);

1.2、属性

JSX中可以像HTML中一样使用"字符串"的属性,也可以使用{表达式}属性:

const element = <div tabIndex="0"></div>;
const element = <img src={user.avatarUrl}></img>;

注意:

1、React DOM 使用 camelCase 小驼峰命名 来定义属性的名称,而不是使用 HTML 的属性名称。例如font-size要改为fontSize。

2、HTML中的保留字不能用于js中,例如class,应改为className:

const ele= <div className="red">Red Color</div>

3、JSX中行内样式style需要用一个对象返回,而不是字符串:

const ele=<div style="color:red">Red</div>     //会报错
const ele= <div style={{color:'red'}}>Red</div>

{{color:red}}中第一个大括号代表这是一个js表达式,第二个代表这是一个用大括号引起的对象

1.3、嵌套

如果 JSX 标签是闭合式的,那么需要在结尾处用 />:

const element = <img src={user.avatarUrl} />;

jJSX内含多个标签时,返回时需要在最外面用一个div把它们包起来:

const element = (
 <div>
  <h1>Hello!</h1>
  <h2>Good to see you here.</h2>
 </div>
);

1.4、注释

在jsx中的注释要单独占一行,且用大括号包起来,例如:{/*注释*/},否则有可能会被当成普通文本,引起错误。

2、事件

react事件的绑定采用驼峰写法onClick={this.function}

例如定义一个切换ON/OFF的函数shiftFlag:

class Toggole extends React.Component{
 constructor(props){
  super(props);
  this.state={
   flag:true
  };
  this.shiftFlag=this.shiftFlag.bind(this);   //函数shiftFlag绑定this
 }
 shiftFlag(e){
  e.preventDefault();
  this.setState({
   flag:!this.state.flag
  });
 }
 render(){
  return <a href="#" rel="external nofollow" onClick={this.shiftFlag}>{this.state.flag?'ON':'OFF'}</a>
 }
}

注:

1、类的方法默认是不会绑定this的,直接在方法shiftFlag中使用this会报错this is undefined,因此需要为shiftFlag绑定this。

2、e是一个事件参数,使用e.preventDefault()方法来阻止a标签的默认跳转行为。

react事件参数的传递通过绑定来实现,在传递时,绑定的this在前,参数在后。在定义函数时,事件对象e要放在最后,例如定义一个setName函数修改name为传入的参数:

class Name extends React.Component{
 constructor(props){
  super(props);
  this.state={
   name:'default'
  }
 }
 setName(name,e){   //事件e放在最后
  this.setState({
   name:name
  })
 }
 render(){
  return <button onClick={this.setName.bind(this,'tory')}>{this.state.name}</button>
 }
}

希望本文所述对大家React程序设计有所帮助。

Javascript 相关文章推荐
小型js框架veryide.librar源代码
Mar 05 Javascript
把字符串按照特定的字母顺序进行排序的js代码
Jan 28 Javascript
js实现鼠标触发图片抖动效果的方法
Feb 27 Javascript
很棒的vue弹窗组件
May 24 Javascript
详解vue-meta如何让你更优雅的管理头部标签
Jan 18 Javascript
node.js文件上传重命名以及移动位置的示例代码
Jan 19 Javascript
详解如何用webpack4从零开始构建react开发环境
Jan 27 Javascript
JS实现的类似微信聊天效果示例
Jan 29 Javascript
微信小程序云开发修改云数据库中的数据方法
May 18 Javascript
vue+axios实现post文件下载
Sep 25 Javascript
JavaScript正则表达式验证登录实例
Mar 18 Javascript
为react组件库添加typescript类型提示的方法
Jun 15 Javascript
vue学习之Vue-Router用法实例分析
Jan 06 #Javascript
借助云开发实现小程序短信验证码的发送
Jan 06 #Javascript
React学习之受控组件与数据共享实例分析
Jan 06 #Javascript
Node.js创建一个Express服务的方法详解
Jan 06 #Javascript
JS正则表达式验证端口范围(0-65535)
Jan 06 #Javascript
基于jQuery实现挂号平台首页源码
Jan 06 #jQuery
JS实现音乐导航特效
Jan 06 #Javascript
You might like
玛琪朵 Macchiato
2021/03/03 咖啡文化
劣质的PHP代码简化
2010/02/08 PHP
php ctype函数中文翻译和示例
2014/03/21 PHP
Yii入门教程之目录结构、入口文件及路由设置
2014/11/25 PHP
php生成数字字母的验证码图片
2015/07/14 PHP
PHP memcache在微信公众平台的应用方法示例
2017/09/13 PHP
Laravel Intervention/image图片处理扩展包的安装、使用与可能遇到的坑详解
2017/11/14 PHP
PHP实现小程序批量通知推送
2018/11/27 PHP
CSS+JS构建的图片查看器
2006/07/22 Javascript
禁止js文件缓存的代码
2010/04/09 Javascript
实现只能输入数字的input不用replace方法
2013/09/12 Javascript
简介JavaScript中POSITIVE_INFINITY值的使用
2015/06/05 Javascript
JavaScript中函数(Function)的apply与call理解
2015/07/08 Javascript
EasyUi中的Combogrid 实现分页和动态搜索远程数据
2016/04/01 Javascript
Javascript对象字面量的理解
2016/06/22 Javascript
Bootstrap Validator 表单验证
2016/07/25 Javascript
js实现产品缩略图效果
2017/03/10 Javascript
基于vue2.0实现的级联选择器
2017/06/09 Javascript
详解基于Bootstrap+angular的一个豆瓣电影app
2017/06/26 Javascript
纯js实现画一棵树的示例
2017/09/05 Javascript
webpack-url-loader 解决项目中图片打包路径问题
2019/02/15 Javascript
详解微信小程序胶囊按钮返回|首页自定义导航栏功能
2019/06/14 Javascript
vue 添加和编辑用同一个表单,el-form表单提交后清空表单数据操作
2020/08/03 Javascript
Python中join函数简单代码示例
2018/01/09 Python
Python下简易的单例模式详解
2019/04/08 Python
python实现合并多个list及合并多个django QuerySet的方法示例
2019/06/11 Python
python常见字符串处理函数与用法汇总
2019/10/30 Python
解决python web项目意外关闭,但占用端口的问题
2019/12/17 Python
承诺书的格式范文
2014/03/28 职场文书
2014年财政所工作总结
2014/11/22 职场文书
汽车转让协议书
2015/01/29 职场文书
有关朝花夕拾的读书笔记
2015/06/29 职场文书
《家》读后感:万惜拯救,冷暖自知
2019/09/25 职场文书
MySQL中使用or、in与union all在查询命令下的效率对比
2021/05/26 MySQL
教你一步步实现一个简易promise
2021/11/02 Javascript
Windows Server 2008配置防火墙策略详解
2022/06/28 Servers