1)使用 JSX 的好处

1.提供更加语意化且易懂的标签

与html对比

<!--HTML写法-->
<form class="messageBox">
<textarea></textarea>
<button type="submit"></button>
</form> //jsx写法
<MessageBox />

1.1命令式 对比 声明式
React 思路认为使用 Component 比起模版(Template)和显示逻辑(Display Logic)更能实现关注点分离的概念,而搭配 JSX 可以实现声明式Declarative (注重 what to),而非命令式 Imperative (注重 how to)的程序编写方式

//命令式写法
if(userLikes()) {
if(!hasBlueLike()) {
removeGrayLike();
addBlueLike();
}
} else {
if(hasBlueLike()) {
removeBlueLike();
addGrayLike();
}
} //声明式写法
if(this.state.liked) {
return (<BlueLike />);
} else {
return (<GrayLike />);
}

2.更加简洁

虽然最终 JSX 会转换成 JavaScript,但使用 JSX 可以让程序看起来更加简洁,

//以下为使用 JSX
<a href="https://facebook.github.io/react/">Hello!</a> //不使用jsx
// React.createElement(元件/HTML标签, 元件属性,以对象表示, 子元件)
React.createElement('a', {href: 'https://facebook.github.io/react/'}, 'Hello!')

3.结合原生 Js 语法

// const 为常数
const lists = ['JavaScript', 'Java', 'Node', 'Python'];
class HelloMessage extends React.Component {
render() {
return (
<ul>
{lists.map((result, index) => {
return (<li key={index}>{result}</li>);
})}
</ul>);
}
}

2)JSX 用法摘要

1.环境设定与使用方式

1.1jsx使用方式

  1. 使用 browserify 或 webpack 等 CommonJS bundler 并整合babel 预处理
  2. 于浏览器端做解析

1.2加载 JSX 方式

两种加载方式:

//内嵌
<script type="text/babel">
ReactDOM.render(
<div>hello react!!</div>,
document.getElementById('example')
);
</script> //从外部引入
<script type="text/jsx" src="main.jsx"></script>

2.标签用法

JSX 标签非常类似 XML ,可以直接书写。一般 Component 命名首字大写,HTMLTags 小写。

//以下是一个建立 Component 的 class
class HelloMessage extends React.Component {
render() {
return (
<div>
<p>Hello React!</p>
<MessageList />
</div>
);
}
}

3.转换成 Js

JSX 最终会转换成浏览器可以读取的 JavaScript
转换规则

React.createElement(
string/ReactClass, // 表示 HTML 元素或是 React Component
[object props], // 属性值,用对象表示
[children] // 接下来参数皆为元素子元素
)

解析前(特别注意在 JSX 中使用 JavaScript 表达式时使用 {} 括起,如下方范例的 text ,里面对应的是变数。若需希望放置一般文字,请加上 '' )

var text = 'Hello React';
<h1>{text}</h1>
<h1>{'text'}</h1>

解析完后

另外要特别要注意的是由于 JSX 最终会转成 JavaScript 且每一个 JSX 节点都对应到一个 JavaScript 函数,所以在 Component 的 render 方法中只能回传一个根节点(Root Nodes)。

例如:若有多个 <div> 要 render 请在外面包一个Component 或 <div> 、 <span> 元素。

var text = 'Hello React';
React.createElement("h1", null, "Hello React!");

4.注解(注释)

由于 JSX 最终会编译成 JavaScript,注解也一样使用 // 和 /**/ 当做注解方式

// 单行注解
/*
多行注解
*/ var content = (
<List>
{/* 若是在子元件注解要加 {} */}
<Item
/* 多行
注解
喔 */
name={window.isLoggedIn ? window.name : ''} // 单行注解
/>
</List>
);

5.属性

在 HTML 中,我们可以通过标签上的属性来改变标签外观样式,在 JSX 中也可以。
【注意】class 和 for 由于为 JavaScript 保留关键字用法,因此在 JSX中使用 className 和 htmlFor 替代。

class HelloMessage extends React.Component {
render() {
return (
<div className="message">
<p>Hello React!</p>
</div>
);
}
}

5.1Boolean 属性

在 JSX 中预设只有属性名称但没设值为 true

//例如以下第一个 input 标签disabled 虽然没设值,但结果和下面的 input 为相同
<input type="button" disabled />;
<input type="button" disabled={true} />; //反之,若是没有属性,则预设预设为 false :
<input type="button" />;
<input type="button" disabled={false} />;

6.扩展属性

在 ES6 中使用 ... 是迭代对象的意思,可以把所有对象对应的值迭代出来设定属性,但要注意后面设定的属性会盖掉前面相同属性:

var props = {
style: "width:20px",
className: "main",
value: "yo",
}
<HelloMessage {...props} value="yo" />
// 等于以下
React.createElement("h1", React._spread({}, props, {value: "yo"}
), "Hello React!");

7.自定义属性

若是希望使用自定义属性,可以使用 data- :

<HelloMessage data-attr="xd" />

8.显示 HTML

通常为了避免信息安全问题,我们会过滤掉 HTML,若需要显示的话可以使用:

<div>{{_html: '<h1>Hello World!!</h1>'}}</div>

9.样式使用

在 JSX 中使用外观样式方法如下,第一个 {} 是 JSX 语法,第二个为JavaScript 对象。与一般属性值用 - 分隔不同,为驼峰式命名写法:

<HelloMessage style={{ color: '#FFFFFF', fontSize: '30px'}} />

10.事件处理

事件处理为前端开发的重头戏,在 JSX 中通过 inline 事件的绑定来监听并处理事件(注意也是驼峰式写法)

<HelloMessage onClick={this.onBtn} />

更多事件处理参考:https://reactjs.org/docs/events.html#supported-events

三、jsx简化教程的更多相关文章

  1. Win7+ubuntu kylin+CentOS 6.5三系统安装图文教程

    Win7+ubuntu kylin+CentOS 6.5三系统安装图文教程 引言:原本机子上已经装好了win7+Ubuntu Kylin 由win7引导,而不是Ubuntu的grub引导的双系统(安装 ...

  2. 技能|三次简化一张图:一招理解LSTM/GRU门控机制

    作者 | 张皓 引言 RNN是深度学习中用于处理时序数据的关键技术, 目前已在自然语言处理, 语音识别, 视频识别等领域取得重要突破, 然而梯度消失现象制约着RNN的实际应用.LSTM和GRU是两种目 ...

  3. mysql进阶(三)游标简易教程

    mysql游标简易教程 从mysql V5.5开始,进行了一次大的改变,就是将InnoDB作为默认的存储引擎.InnoDB支持事务,而且拥有相关的RDBMS特性:ACID事务支持,数据完整性(支持外键 ...

  4. Python基础(三):简化除法判断、分析apache访问日志、扫描存活主机、利用多线程实现ssh并发访问

    一.简化除法判断 目标: 编写mydiv.py脚本,主要要求如下: 提示用户输入一个数字作为除数 如果用户按下Ctrl+C或Ctrl+D则退出程序 如果用户输入非数字字符,提示用户应该输入数字 如果用 ...

  5. 从头開始学 RecyclerView(三) 封装简化

    前言 上一篇的代码,也是基于这些封装的. RV的封装,跟曾经的listView之类的封装,大同小异. 这里,从@devwiki 处,将代码搬过来.基本无改动 BaseHolder的优化 使ViewHo ...

  6. 【转载】Gradle学习 第三章:教程

    转载地址:http://ask.android-studio.org/?/article/15 3.1. Getting Started 入门The following tutorials intro ...

  7. U盘装系统系列三—-ghost系统安装教程

    前面和大家分享了如何用老毛桃U盘启动盘制作工具把U盘制作启动盘,接下来说下制作好启动盘之后如何安装ghost系统.首先我们准备好ghost镜像复制到U盘中:然后用U盘启动:选择[01]后按Enter键 ...

  8. WorkerMan 入门学习之(三)基础教程-Timer类的使用

    1.ServerTimer.php 代码: <?php /** * 定时器学习 */ require_once __DIR__ . '/Workerman/Autoloader.php'; us ...

  9. WPF入门教程系列二十三——DataGrid示例(三)

    DataGrid的选择模式 默认情况下,DataGrid 的选择模式为“全行选择”,并且可以同时选择多行(如下图所示),我们可以通过SelectionMode 和SelectionUnit 属性来修改 ...

随机推荐

  1. 二十 Spring的事务管理及其API&事务的传播行为,编程式&声明式(xml式&注解式,底层AOP),转账案例

    Spring提供两种事务方式:编程式和声明式(重点) 前者需要手写代码,后者通过配置实现. 事务的回顾: 事务:逻辑上的一组操作,组成这组事务的各个单元,要么全部成功,要么全部失败 事务的特性:ACI ...

  2. 重大消息:华为笔记本电脑开始用LINUX系统

    对华为而言,此举不失为一个明智的抉择.在手机操作系统领域,目前已被苹果的IOS系统和谷歌的安卓系统垄断.而IOS系统是封闭式,只为苹果手机使用:安卓是开放性,当谷歌与华为停止合作后.华为手机将无法使用 ...

  3. Android加载手机磁盘上的资源---decodeFile方法的使用

    一般在写Android程序时,通常会将图片资源放在/res/drawable/文件夹下,读取时,通过R.drawable.imageId即可读取图片内容,但用户在使用时,一般会想要读取存放在存储卡上的 ...

  4. MariaDB——备份与恢复

    备份和恢复 为什么要备份?   灾难恢复:硬件故障.软件故障.自然灾害.黑客攻击.误操作   测试   要注意的点:   备份需要多少时间   能够容忍多少的数据丢失   恢复数据需要在多长时间完成  ...

  5. 引用类型--Date类型

    要创建一个日期对象,使用new操作符和Date构造函数即可. var now = new Date() 在调用Date构造函数而不传递参数的情况下,新创建的对象自动获得当前日期和时间.如果想根据特定的 ...

  6. 洛谷 P1094 纪念品分类

    刚开始看到这题就确定这题最好先要排序 第一个想法是排好序后先让第一个和从倒数第一个开始相加和如果就  <= w,那么用n除以2或者再加一得出答案,然后发现随便 当w = 110  n = 5序列 ...

  7. 「NOIP2007」树网的核

    传送门 Luogu 解题思路 这里着重介绍 \(O(n^3)\) 的做法,毕竟考场上只有 \(N\le300\) \(Q \omega Q\) 首先我们要知道,对任意一条直径算偏心距都是一样的. 证明 ...

  8. golang的传值调用和传引用调用

    传值还是传引用 调用函数时, 传入的参数的 传值 还是 传引用, 几乎是每种编程语言都会关注的问题. 最近在使用 golang 的时候, 由于 传值 和 传引用 的方式没有弄清楚, 导致了 BUG. ...

  9. 前端学习笔记系列一:1.export default / export const

    export default 是默认导出 export const 是命名导出 参考:Javascript (ES6), export const vs export default(基本上就是翻译这 ...

  10. wumii 爆款总结经验

    在正式创办无秘之前,我们反思前几次创业失败的教训,深刻领悟两点: 第一,内容推荐的精准度取决于平台收集用户数据的能力,如果没有用户行为数据,产品无法做内容推荐,而通过简单的新闻排序,延长用户浏览单篇文 ...