【译】快速起步-JSX简介
react version: 15.5.0
快速起步-JSX简介
思考这个变量申明:
const element = <h1>Hello, world!</h1>;
这个有趣的标签语法既不是字符串也不是HTML。
它被称之为 JSX
,是 JavaScript
的语法扩展。我们建议使用它来定义React的UI展示。JSX
可能会让你想起模板语言,但它可以使用 JavaScript
的全部功能。
JSX
用于编写 React "elements"
。在 下一节,我们将探索如何将它们渲染到DOM中。下面,我们来了解下 JSX
的基础知识。
在 JSX
中嵌入表达式
你可以在 JSX
中通过 {xxx}
来嵌入 JavaScript 表达式。
例如,2 + 2
, user.firstName
, 和 formatName(user)
都是合法的表达式:
function formatName(user) {
return user.firstName + ' ' + user.lastName;
}
const user = {
firstName: 'Harper',
lastName: 'Perez'
};
const element = (
<h1>
Hello, {formatName(user)}!
</h1>
);
ReactDOM.render(
element,
document.getElementById('root')
);
为了可读性,我们将 JSX
分割为多行。虽然这不是必须的,但在这样做的时候,我们建议将它放在 {}
中,以避免 自动补全分号。
JSX 也是一个表达式
编译之后,JSX表达式会变成常规的 JavaScript
对象。
这意味着你可以在 if
语句和 for
循环内部使用 JSX
,也可以将其作为参数传递或用来作为返回值:
function getGreeting(user) {
if (user) {
return <h1>Hello, {formatName(user)}!</h1>;
}
return <h1>Hello, Stranger.</h1>;
}
JSX中指定属性
您可以使用引号将字符串文本指定为属性:
const element = <div tabIndex="0"></div>;
你也可以使用 {}
将 JavaScript
表达式作为属性:
const element = <img src={user.avatarUrl}></img>;
在属性中使用 JavaScript
表达式时,不要使用引号包裹大括号。否则,JSX会认为属性值是字符串而不是一个表达式。你可以对字符串使用双引号,对表达式使用花括号,但不能同时使用。
JSX中指定子集
如果是空标签,可以像XML那样使用自闭合标签 />
:
const element = <img src={user.avatarUrl} />;
JSX 标签也可以包含子集:
const element = (
<div>
<h1>Hello!</h1>
<h2>Good to see you here.</h2>
</div>
);
警告:
由于 JSX 更趋近于 JavaScript 而不是 HTML,React DOM 使用
camelCase
(小驼峰) 属性命名约定而不是HTML的属性名称。
JSX 防止注入攻击
在 JSX
中嵌入用户输入是安全的:
const title = response.potentiallyMaliciousInput;
// 安全的:
const element = <h1>{title}</h1>;
默认情况下,React DOM 会在渲染前使用 escapes 编码所有嵌入 JSX
的值。 因此它能确保您永远不会注入任何未明确写入应用程序的内容。所有内容都将在呈现前转换为字符串。这有助于防御 XSS (cross-site-scripting) 攻击。
JSX 代表对象
Babel
将 JSX
编译成 React.createElement()
调用。
这两个例子是等同的:
const element = (
<h1 className="greeting">
Hello, world!
</h1>
);
const element = React.createElement(
'h1',
{className: 'greeting'},
'Hello, world!'
);
React.createElement()
会执行一些检查来帮助您编写无误的代码,但基本上,它是创建如下的对象:
// 注意:以下是简单结构
const element = {
type: 'h1',
props: {
className: 'greeting',
children: 'Hello, world'
}
};
这些对象称之为 "React elements". 你可以将它们视为您想要在屏幕上看到的内容。React
会读取这些对象,并使用它们来构造DOM且保持为最新状态。
下一节我们将探索如何渲染 React elements
到DOM中。
提示:
我们建议为编辑器选择
Babel
语法支持插件,以便ES6
和JSX
都能被高亮显示。
【译】快速起步-JSX简介的更多相关文章
- 【译】Android系统简介—— Activity
续上一篇,继续介绍Android系统.上一篇: [译]Android系统简介 本文主要介绍构建Android应用的一些主要概念: Activity Activity是应用程序中一个单独的有UI的页面( ...
- React基础篇 - 02.JSX 简介
JSX 简介 请观察下面的变量声明: const element = <h1>Hello, world!</h1>; 这种看起来可能有些奇怪的标签语法既不是字符串也不是HTML ...
- JSX 简介
JSX 简介 考虑如下变量声明: const element = <h1>Hello, world!</h1>; 这个有趣的标签语法既不是字符串也不是HTML. 它被称为JSX ...
- Kafka 快速起步(作者:杜亦舒)
Kafka 快速起步 原创 2017-01-05 杜亦舒 性能与架构 主要内容:1. kafka 安装.启动2. 消息的 生产.消费3. 配置启动集群4. 集群下的容错测试5. 从文件中导入数据,并导 ...
- JUnit三分钟教程 ---- 快速起步
JUnit三分钟教程 ---- 快速起步 摘自http://lavasoft.blog.51cto.com/62575/65625/ JUnit是个好东西,做大点的项目离不开这东西,实际中用的时候也因 ...
- React文档翻译系列(三)JSX简介
# React文档翻译系列(三)JSX简介 先来看一下下面的变量声明: ``` const element = Hello world! ``` 这种有趣的标签语法既不是字符串也不是HTML. 这种形 ...
- Kafka 快速起步
Kafka 快速起步 原创 2017-01-05 杜亦舒 性能与架构 性能与架构 性能与架构 微信号 yogoup 功能介绍 网站性能提升与架构设计 主要内容:1. kafka 安装.启动2. 消息的 ...
- React学习笔记 - JSX简介
React Learn Note 2 React学习笔记(二) 标签(空格分隔): React JavaScript 一.JSX简介 像const element = <h1>Hello ...
- jsx简介
react文档笔记 jsx简介 jsx是一种javascript的语法扩展,jsx用来声明React当中的元素. 在jsx中使用表达式 jsx当中的表达式要包含在大括号里.例如2+2,user.fir ...
随机推荐
- Python参数传递(传值&传引用)
# 测试参数是传值还是传引用def test(arg): print("test before") print(id(arg)) arg[1]=30 # 测试可变对象 # arg[ ...
- Python之逻辑回归
代码: import numpy as np from sklearn import datasets from sklearn.linear_model import LogisticRegress ...
- early_suspend【转】
android 休眠唤醒机制分析(二) - early_suspend early_suspend是Android休眠流程的第一阶段即浅度休眠,不会受到wake_lock的阻止,一般用于关闭lcd.t ...
- Java中常用的字节流和字符流
IO流(输入流.输出流) 字节流.字符流 1.字节流: InputStream.OutputStream InputStream抽象了应用程序读取数据的方式: OutputStream抽象了应用程序写 ...
- Matplotlib:tick_params参数设置
1.tick_params语法 参数:axis : {‘x’, ‘y’, ‘both’} Axis on which to operate; default is ‘both’.reset : boo ...
- win10系统安装两个版本的python,该怎么安装Django
最近遇到一个问题,系统上安装了python2,7 和python3.5两个版本,然后使用命令:pip install Django 安装Django后却发现以下情况: Traceback (most ...
- 开启 J2EE(一)—‘全明星队伍’
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/akkzhjj/article/details/27973427 J2EE-一套规范 J2EE(Jav ...
- Vue:渲染、指令、事件、组件、Props
每天学习一点点 编程PDF电子书免费下载: http://www.shitanlife.com/code 如果要我用一句话描述使用 Vue 的经历,我可能会说“它如此合乎常理”或者“它提供给我需要的工 ...
- CSS中background属性详解
CSS背景属性 background css 说明 background-image:url(图片的网址); 背景图 background: url( 图片的网址 ); 背景 background-c ...
- mysql5.7配置文件优化
[mysqld] pid-file = /var/run/mysqld/mysqld.pid socket = /var/run/mysqld/mysqld.sock datadir = /var/l ...