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 + 2user.firstNameformatName(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简介的主要内容,如果未能解决你的问题,请参考以下文章

33.react入门

react.js JSX 简介

React 的 JSX 简介

将数据从服务器(Node.js)发送到 GraphQL 服务器中的客户端(React 组件)

React.js学习之理解JSX和组件

三剑合璧:Node.js+React.js+vue.js开发3大最前沿项目!升职加薪统统收入麾下!| 饥人谷