2022 React 最速上手指南(二)—— 组件 & JSX

简介: 2022 React 最速上手指南(二)—— 组件 & JSX

以结果为导向,写给刚学完前端三剑客和想要了解 React 框架的小伙伴,使得他们能快速上手(省略了历史以及一些不必要的介绍)。



组件 & JSX


我们的第一个组件就在 src/App.js 文件中,是一个常规的 JS 函数(但名称必须以大写字母开头),你可以删除模板自动生成的部分代码并将其简化为以下形式:


function App() {
  return (
    <div>
      <h1>Hello World</h1>
    </div>
  );
}
export default App;
复制代码


在你保存后,浏览器将会显示 Hello World 的结果。


可以看到 App 组件返回了类似 HTML 的输出,这样的将 HTML 和 JavaScript 混合在一起的输出叫做 JSX,它可以用来生成 React 元素,同时 return 多行必须将其包在一对括号中。


如果你在开头定义了一个变量,你可以这样展示:


const title = "React";
function App() {
  return (
    <div>
      <h1>Hello {title}</h1>
    </div>
  );
}
export default App;
复制代码


而 HTML 的部分与原生几乎相同,如果要写一个输入框你可以这样定义:


<label htmlFor="search">Search: </label>
<input type="text" id="search"/>
复制代码


可以看到只有 htmlFor 不认识,但也可以猜到是 for 属性的代替。React 约定使用驼峰命名法,所以很多属性与原生不同,比如 classonclick 在 JSX 中是 classNameonClick,你可以在 React 文档中找到更多支持的属性。


而且 JSX 花括号内的所有内容都可以使用 JS 表达式,例如函数执行:


function getName(name) {
  return "Hello " + name;
}
export default function App() {
  return (
    <div>
      <h1>{getName("Mancuoj")}</h1>
      <label htmlFor="search">Search: </label>
      <input type="text" id="search"/>
    </div>
  );
}
复制代码


export default 是标准的 JS 语法(并不特定于 React),可以导出函数对象或原始值,以便在其他文件中使用 import 导入。这里我们也可以简化一下,直接默认导出函数的返回值。


专栏


因为参加打卡活动是每日更新,所以可能比较短小,可以关注一下 React 入门专栏

在更新完后会整合为一整篇,感谢关注和点赞!

目录
相关文章
|
21天前
|
前端开发 开发者
React 函数组件与类组件对比
【10月更文挑战第4天】本文详细比较了React中的函数组件与类组件。函数组件是一种简单的组件形式,以纯函数的形式返回JSX,易于理解与维护,适用于简单的UI逻辑。类组件则是基于ES6类实现的,需要重写`render`方法并能利用更多生命周期方法进行状态管理。文章通过示例代码展示了两者在状态管理与生命周期管理上的差异,并讨论了常见的问题如状态更新异步性与生命周期管理的复杂性,最后给出了相应的解决方法。通过学习,开发者可以根据具体需求选择合适的组件类型。
44 8
|
2月前
|
前端开发 JavaScript
学习react基础(3)_setState、state、jsx、使用ref的几种形式
本文探讨了React中this.setState和this.state的区别,以及React的核心概念,包括核心库的使用、JSX语法、类与函数组件的区别、事件处理和ref的使用。
51 3
学习react基础(3)_setState、state、jsx、使用ref的几种形式
|
19天前
|
人工智能 自然语言处理 前端开发
SpringBoot + 通义千问 + 自定义React组件:支持EventStream数据解析的技术实践
【10月更文挑战第7天】在现代Web开发中,集成多种技术栈以实现复杂的功能需求已成为常态。本文将详细介绍如何使用SpringBoot作为后端框架,结合阿里巴巴的通义千问(一个强大的自然语言处理服务),并通过自定义React组件来支持服务器发送事件(SSE, Server-Sent Events)的EventStream数据解析。这一组合不仅能够实现高效的实时通信,还能利用AI技术提升用户体验。
97 2
|
2月前
|
前端开发 JavaScript 网络架构
react对antd中Select组件二次封装
本文介绍了如何在React中对Ant Design(antd)的Select组件进行二次封装,包括创建MSelect组件、定义默认属性、渲染Select组件,并展示了如何使用Less进行样式定义和如何在项目中使用封装后的Select组件。
68 2
react对antd中Select组件二次封装
|
6天前
|
前端开发 JavaScript 测试技术
React 高阶组件 (HOC) 应用
【10月更文挑战第16天】高阶组件(HOC)是 React 中一种复用组件逻辑的方式,通过接受一个组件并返回新组件来实现。本文介绍了 HOC 的基础概念、核心功能和常见问题,包括静态方法丢失、ref 丢失、多个 HOC 组合和 props 冲突的解决方案,并提供了具体的 React 代码示例。通过本文,读者可以更好地理解和应用 HOC,提高代码的复用性和可维护性。
25 8
|
6天前
|
缓存 前端开发 JavaScript
前端serverless探索之组件单独部署时,利用rxjs实现业务状态与vue-react-angular等框架的响应式状态映射
本文深入探讨了如何将RxJS与Vue、React、Angular三大前端框架进行集成,通过抽象出辅助方法`useRx`和`pushPipe`,实现跨框架的状态管理。具体介绍了各框架的响应式机制,展示了如何将RxJS的Observable对象转化为框架的响应式数据,并通过示例代码演示了使用方法。此外,还讨论了全局状态源与WebComponent的部署优化,以及一些实践中的改进点。这些方法不仅简化了异步编程,还提升了代码的可读性和可维护性。
|
8天前
|
XML 前端开发 JavaScript
React JSX
React 使用 JSX(一种类似 XML 的 JavaScript 语法扩展)来替代传统 JavaScript 编写 UI。JSX 使代码更简洁、执行更快且类型安全。例如,`&lt;h1&gt;Hello, world!&lt;/h1&gt;` 实际上是创建一个 React 元素,通过 `ReactDOM.render()` 渲染到 DOM。注意,JSX 中使用 `className` 替代 HTML 的 `class` 属性。
|
18天前
|
前端开发 JavaScript 调度
React 组件状态(State)
10月更文挑战第8天
13 1
|
19天前
|
XML 前端开发 JavaScript
React JSX
10月更文挑战第7天
13 2
|
2月前
|
前端开发
React给antd中TreeSelect组件左侧加自定义图标icon
本文介绍了如何在React中为Ant Design的TreeSelect组件的每个树节点添加自定义图标,并解决了因缺少key属性而导致的警告问题,展示了如何通过递归函数处理treeData数据并为每个节点添加图标。
44 2
React给antd中TreeSelect组件左侧加自定义图标icon