JSX 是一个看起来很像 XML 的 JavaScript 语法扩展。React 可以用来做简单的 JSX 句法转换。

为什么要使用 JSX?

你不需要为了 React 使用 JSX,可以直接使用纯粹的 JS。但我们更建议使用 JSX , 因为它能定义简洁且我们熟知的包含属性的树状结构语法。

对于非专职开发者(比如设计师)同样比较熟悉。

XML 有固定的标签开启和闭合。这能让复杂的树更易于阅读,优于方法调用和对象字面量的形式。

它没有修改 JavaScript 语义。

HTML标签 与 React组件 对比

React 可以渲染 HTML 标签 (strings) 或 React 组件 (classes)。

要渲染 HTML 标签,只需在 JSX 里使用小写字母开头的标签名。

var myDivElement = <div className="foo" />;
React.render(myDivElement, document.body);

要渲染 React 组件,只需创建一个大写字母开头的本地变量。

var MyComponent = React.createClass({/*...*/});
var myElement = <MyComponent someProperty={true} />;
React.render(myElement, document.body);

React 的 JSX 里约定分别使用首字母大、小写来区分本地组件的类和 HTML 标签。

注意:

由于 JSX 就是 JavaScript,一些标识符像 class 和 for 不建议作为
XML 属性名。作为替代,React DOM 使用 className 和 htmlFor 来做对应的属性。

转换

JSX 把类 XML 的语法转成纯粹 JavaScript,XML 元素、属性和子节点被转换成React.createElement 的参数。

var Nav;
// 输入 (JSX):
var app = <Nav color="blue" />;
// 输出 (JS):
var app = React.createElement(Nav, {color:"blue"});

注意,要想使用 <Nav />Nav 变量一定要在作用区间内。

JSX 也支持使用 XML 语法定义子结点:

var Nav, Profile;
// 输入 (JSX):
var app = <Nav color="blue"><Profile>click</Profile></Nav>;
// 输出 (JS):
var app = React.createElement(
  Nav,
  {color:"blue"},
  React.createElement(Profile, null, "click")
);

使用 JSX 编译器 来试用 JSX 并理解它是如何转换到原生 JavaScript,还有 HTML
到 JSX 转换器
 来把现有 HTML 转成 JSX。

如果你要使用 JSX,这篇 新手入门 教程来教你如何搭建环境。

注意:

JSX 表达式总是会当作 ReactElement 执行。具体的实际细节可能不同。一种优化 的模式是把 ReactElement 当作一个行内的对象字面量形式来绕过React.createElement 里的校验代码。

JavaScript 表达式

属性表达式

要使用 JavaScript 表达式作为属性值,只需把这个表达式用一对大括号 ({}) 包起来,不要用引号 ("")。

// 输入 (JSX):
var person = <Person name={window.isLoggedIn ? window.name : ''} />;
// 输出 (JS):
var person = React.createElement(
  Person,
  {name: window.isLoggedIn ? window.name : ''}
);

子节点表达式

同样地,JavaScript 表达式可用于描述子结点:

// 输入 (JSX):
var content = <Container>{window.isLoggedIn ? <Nav /> : <Login />}</Container>;
// 输出 (JS):
var content = React.createElement(
  Container,
  null,
  window.isLoggedIn ? React.createElement(Nav) : React.createElement(Login)
);

注释

JSX 里添加注释很容易;它们只是 JS 表达式而已。你只需要在一个标签的子节点内(非最外层)小心地用 {} 包围要注释的部分。

var content = (
  <Nav>
    {/* 一般注释, 用 {} 包围 */}
    <Person
      /* 多
         行
         注释 */
      name={window.isLoggedIn ? window.name : ''} // 行尾注释
    />
  </Nav>
);

注意:

JSX 类似于 HTML,但不完全一样。参考 JSX 陷阱 了解主要不同。

最新文章

  1. golang中不定参数与数组切片的区别
  2. HDU 1083 网络流之二分图匹配
  3. flash的动态加载技术
  4. Windows编程基础
  5. SQL Server数据库多种方式查找重复记录
  6. Javascript 原型继承(续)—从函数到构造器的角色转换
  7. [MODx] 5. WayFinder
  8. TCP/IP协议原理与应用笔记11:TCP/IP中地址与层次关系
  9. 网易新闻首页iOS
  10. Sliverlight之 矢量绘图
  11. python实现邮件发送
  12. js判断字符串中是否有数字和字母
  13. 小米Java程序员第二轮面试10个问题,你是否会被刷掉?
  14. Python基础(函数-递归)
  15. SSH执行hql报错:Caused by: org.hibernate.hql.ast.QuerySyntaxException: user is not mapped [from user where username = ?]
  16. Spring mvc集成log4j2
  17. thusc2017
  18. eclipse中启动项目报内存溢出问题通过修改配置解决
  19. Linux(CentOS6)系统安装Windows字体
  20. [转][C#]Web.config 相关配置

热门文章

  1. Git 常用命令速查表
  2. Linux操作系统进程模型分析进程
  3. Ubuntu 16.04 + ROS Kinetic 机器人操作系统学习镜像分享与使用安装说明
  4. zookeeper基本原理及适用场景 转:http://blog.chinaunix.net/uid-26748613-id-4536290.html
  5. 安卓高级4 第三方库SlidingMenu的使用
  6. 让你的代码量减少3倍!使用kotlin开发Android(二) --秘笈!扩展函数
  7. Linux命令行总结
  8. 一个整数数组,长度为n,将其分为m份,使各份的和相等,求m的最大值。
  9. 查看4k对齐,激活.net framework 3.5
  10. RxJava操作符(07-辅助操作)