📅  最后修改于: 2023-12-03 14:53:38.261000             🧑  作者: Mango
JSX 是一个 JavaScript 扩展,用于在 React 应用中描述用户界面。JSX 的语法类似于 HTML,但在内部实现中,它被转换为普通的 JavaScript 函数调用。作为 React 的一部分,JSX 使得构建用户界面变得更加容易和直观。
JSX 中的标签类似于 HTML 标签。例如,如果要渲染一个页面标题,可以像这样编写 JSX:
const title = <h1>Hello, world!</h1>;
与 HTML 不同的是,在 JSX 中,您可以在标签内部嵌入 JavaScript 表达式。例如:
const name = "Jane";
const greeting = <h1>Hello, {name}!</h1>;
在上面的代码中,我们使用了花括号将 JavaScript 表达式嵌入到 Hello,
和 !
标记之间的字符串中。这使得我们可以根据需要动态生成内容。
在渲染 JSX 标签时,您可以将其作为变量或对象属性传递:
const title = <h1>Hello, world!</h1>;
ReactDOM.render(
title,
document.getElementById("root")
);
在上面的代码中,我们将 title
变量传递给 ReactDOM.render()
函数,该函数会将其渲染到具有 root
ID 的 HTML 元素上。
在 React 中,您可以将 UI 呈现为组件树。组件是具有自己状态和属性的可重用 UI 元素。您可以像这样使用组件:
function Welcome(props) {
return <h1>Hello, {props.name}!</h1>;
}
const element = <Welcome name="Alice" />;
ReactDOM.render(
element,
document.getElementById("root")
);
在上面的代码中,我们定义了一个名为 Welcome
的函数组件,该组件是一个接受名为 props
的对象参数的函数,该对象具有一个名为 name
的属性。该组件返回一个 h1
元素,该元素使用 props.name
对象的值来渲染 Hello,
和 !
之间的字符串。
我们使用 <Welcome name="Alice" />
语法将组件呈现为标签,其中 name
属性设置为 Alice
。最后,我们将 <Welcome name="Alice" />
渲染到 root
元素上。
JSX 是 React 应用程序中描述 UI 的一种语法。它类似于 HTML,但在内部被转换为普通的 JavaScript 函数调用。使用 JSX,您可以更轻松地描述 UI,只需像编写 HTML 一样编写 JSX 标记。请参阅 React 文档以获取有关 JSX 语法的更多信息和示例。