Node.js 之react.js组件-JSX简介
Posted yilizhongzi-yilisha
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Node.js 之react.js组件-JSX简介相关的知识,希望对你有一定的参考价值。
JSX 简介
const element = <h1>Hello, world!</h1>;
以上为一个JSX,我的理解(简单理解带有html标签的变量元素)。
简介:是一个 javascript 的语法扩展。我们建议在 React 中配合使用 JSX,JSX 可以很好地描述 UI 应该呈现出它应有交互的本质形式。JSX 可能会使人联想到模版语言,但它具有 JavaScript 的全部功能。
JSX 可以生成 React “元素”。
为什么使用 JSX?
React 认为渲染逻辑本质上与其他 UI 逻辑内在耦合,比如,在 UI 中需要绑定处理事件、在某些时刻状态发生变化时需要通知到 UI,以及需要在 UI 中展示准备好的数据。
React 并没有采用将标记与逻辑进行分离到不同文件这种人为地分离方式,而是通过将二者共同存放在称之为“组件”的松散耦合单元之中,来实现关注点分离。
React 不强制要求使用 JSX,但是大多数人发现,在 JavaScript 代码中将 JSX 和 UI 放在一起时,会在视觉上有辅助作用。它还可以使 React 显示更多有用的错误和警告消息。
在 JSX 中嵌入表达式
在下面的例子中,我们声明了一个名为 name
的变量,然后在 JSX 中使用它,并将它包裹在大括号中:
const name = ‘Josh Perez‘;
const element = <h1>Hello, name</h1>;
ReactDOM.render(
element,
document.getElementById(‘root‘)
);
在 JSX 语法中,你可以在大括号内放置任何有效的 JavaScript 表达式。例如,2 + 2
,user.firstName
或 formatName(user)
都是有效的 JavaScript 表达式。
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 语法上更接近 JavaScript 而不是 HTML,所以 React DOM 使用 camelCase
(小驼峰命名)来定义属性的名称,而不使用 HTML 属性名称的命名约定。
★JSX 表示对象
Babel 会把 JSX 转译成一个名为 React.createElement()
函数调用。
以下两种示例代码完全等效:
const element = (
<h1 className="greeting">
Hello, world!
</h1>
);
const element = React.createElement(
‘h1‘,
className: ‘greeting‘,
‘Hello, world!‘
);
以上是关于Node.js 之react.js组件-JSX简介的主要内容,如果未能解决你的问题,请参考以下文章