React基础 第四章(JSX标签)

JSX是React开发中不可或缺的一部分,它将JavaScript与类HTML的标记语言结合在一起,使得编写UI组件变得直观而高效。本文将基于React官方文档中的知识点,提供一些在开发中常用的技巧、示例代码以及注意事项。

为什么使用JSX

JSX允许你将渲染逻辑与UI标签紧密耦合在一起,这样可以保证在修改组件时,相关的逻辑和UI能够同步更新。

技巧

  • 将渲染逻辑和UI代码放在同一个组件中,以提高代码的可读性和可维护性。

示例

jsx 复制代码
function Button({ label }) {
  return <button>{label}</button>;
}

注意事项

  • 确保组件的逻辑和UI紧密相关,避免将无关的逻辑混入组件中。

JSX与HTML的区别

虽然JSX看起来与HTML非常相似,但它们在一些细节上有所不同。

技巧

  • 使用className代替class属性,因为class是JavaScript中的保留字。
  • 自闭合标签必须以斜杠结束,例如<img />

示例

jsx 复制代码
const Image = () => (
  <img src="https://i.imgur.com/yXOvdOSs.jpg" alt="Hedy Lamarr" className="photo" />
);

注意事项

  • 记住JSX中的所有元素都必须闭合,包括自闭合的标签。

正确代码

jsx 复制代码
// 自闭合标签正确闭合
<img src="https://i.imgur.com/yXOvdOSs.jpg" alt="Hedy Lamarr" className="photo" />

错误代码

jsx 复制代码
// 错误:未正确闭合的自闭合标签
<img src="https://i.imgur.com/yXOvdOSs.jpg" alt="Hedy Lamarr" className="photo">

展示信息

JSX中可以很容易地展示动态信息。

技巧

  • 使用大括号{}来插入JavaScript表达式,包括变量、函数调用等。

示例

jsx 复制代码
function Greeting({ name }) {
  return <h1>欢迎,{name}!</h1>;
}

注意事项

  • 确保插入的JavaScript表达式返回的是React可以渲染的值,例如字符串、数字、元素或组件。

使用Fragment

当需要返回多个元素而不想添加额外的DOM节点时,可以使用React Fragment。

技巧

  • 使用<>...</>作为不添加额外DOM节点的容器。

示例

jsx 复制代码
function TodoList() {
  return (
    <>
      <h1>待办事项</h1>
      <ul>
        <li>学习JSX</li>
        <li>编写组件</li>
      </ul>
    </>
  );
}

注意事项

  • Fragment只是作为包裹元素,并不会渲染任何实际的DOM节点。

通过以上技巧和注意事项,你可以更加自如地使用JSX来构建你的React应用。记住,JSX不仅仅是一个简单的模板语言,它是一个强大的工具,可以让你以声明式的方式来描述你的UI,并且能够完美地与React的组件模型结合。

相关推荐
python在学ing2 分钟前
前端-CSS学习笔记
前端·css·python·学习
Bug-制造者15 分钟前
【Vue3 实战】全局错误处理体系搭建:实现业务与错误彻底解耦
前端·javascript·vue.js
悟空瞎说18 分钟前
# Git 交互式变基:优雅整理提交历史,告别杂乱 PR 记录
前端·git
还有多久拿退休金30 分钟前
DragSortTable:一个让我怀疑人生的滚动重置 Bug
前端
渐儿33 分钟前
组件库开发入门到生产(从零封装到 npm 发布)
前端
KaMeidebaby1 小时前
卡梅德生物技术快报|单 B 细胞抗体制备:流程优化、表达系统适配与性能数据
前端·数据库·其他·百度·新浪微博
lichenyang4531 小时前
从鸿蒙 AI 聊天 Demo 学习 ArkUI V2:第一天上手记录
前端
进击的松鼠2 小时前
OpenClaw 的五层架构设计与解析
前端·架构·agent
JavaGuide2 小时前
Claude Code 新功能Agent View 发布:终于不用在一堆终端窗口里找 Agent 了!
前端·后端·agent
不简说2 小时前
前端可视化打印设计器sv-print,一口气更新了30版
前端·源码·产品