新闻中心

解决 JSX 元素缺少闭合标签错误:理解 React/JSX 语法规范

2025-10-25
浏览次数:
返回列表

解决 JSX 元素缺少闭合标签错误:理解 React/JSX 语法规范

本文详细解析了 react/jsx 开发中常见的“jsx element 'x' has no corresponding closing tag”错误。通过对比错误与正确的 jsx 语法,强调了带内容元素必须使用 `内容` 的完整开闭标签结构,并区分了自闭合标签的适用场景。教程还提供了如何有效解读编译器错误信息,以提升开发效率和代码质量的实用建议。

在 React 应用开发中,JSX 作为 J*aScript 的语法扩展,允许我们在 J*aScript 代码中编写类似 HTML 的结构。然而,JSX 语法有着严格的规范,其中最基础也是最容易出错的一点就是元素的开闭标签匹配。当编译器抛出“JSX element 'div' has no corresponding closing tag.”这样的错误时,通常意味着某个 JSX 元素的闭合方式不符合其预期。

理解 JSX 元素闭合规则

JSX 元素根据其是否包含内容或子元素,分为两种基本的闭合形式:

  1. 带内容的元素(Content-bearing Elements) 如果一个 JSX 元素包含文本、其他 JSX 元素或任何子内容,它必须使用一个完整的开标签和闭标签对。开标签形如 ,闭标签形如

    正确示例:

    <div>这是一个包含内容的 div 元素</div>
    <p>
      <span>这是一个嵌套的 span 元素</span>
    </p>
  2. 自闭合元素(Self-closing Elements) 如果一个 JSX 元素不包含任何子元素或内容,它可以(也应该)使用自闭合标签的形式。这种标签在开标签的末尾加上一个斜杠 /,形如 。HTML 中常见的自闭合标签有 解决 JSX 元素缺少闭合标签错误:理解 React/JSX 语法规范
    等。在 React 中,不接受 children prop 的自定义组件也常使用自闭合形式。

    正确示例:

    @@##@@
    <input type="text" placeholder="请输入..." />
    <MyComponent propA="value" /> {/* 假设 MyComponent 不接受 children */}

解析“JSX element 'div' has no corresponding closing tag.”错误

这个错误通常发生在开发者试图以自闭合的形式来闭合一个预期包含内容的 JSX 元素时。例如,以下代码片段展示了一个典型的错误场景:

万相营造 万相营造

阿里妈妈推出的AI电商营销工具

万相营造 168 查看详情 万相营造

错误示例代码:

return (
  <div className="home">
      {isPending && <div>Loading...<div/>} {/* 错误:此处应为 </div> */}
      {blogs && <Bloglist blogs={blogs} title="All blogs!"/>}
  </div>
);

在这个例子中,

Loading... 这行代码是问题的根源。 元素内部包含文本“Loading...”,因此它是一个带内容的元素,需要一个匹配的闭标签 。然而,代码中却使用了 这种自闭合形式,导致 JSX 编译器无法找到 的对应闭合标签,从而抛出错误。

正确的修改方式: 要解决这个问题,只需将错误的自闭合标签替换为正确的闭标签即可:

return (
  <div className="home">
      {isPending && <div>Loading...</div>} {/* 更正:使用正确的闭标签 </div> */}
      {blogs && <Bloglist blogs={blogs} title="All blogs!"/>}
  </div>
);

通过这次修改,

元素现在有了正确的开标签和闭标签,符合 JSX 语法规范。

注意事项与开发实践

  1. 区分 HTML 元素与自定义组件的闭合: 尽管 看起来是自闭合的,这并不意味着所有组件都必须自闭合。如果 Bloglist 组件需要渲染子元素(即它会处理 props.children),那么它也需要完整的开闭标签,例如 一些子内容。关键在于元素是否包含内容。

  2. 重视编译器错误信息: 当出现编译错误时,仔细阅读错误信息至关重要。错误信息通常会指出发生错误的具体文件、行号和列号,以及错误的类型。例如,"JSX element 'div' has no corresponding closing tag." 明确指出了问题所在——div 元素缺少闭合标签。学会解读这些信息是高效解决问题的第一步。

  3. 利用开发工具辅助: 现代集成开发环境(IDE)如 VS Code、WebStorm 等,以及代码质量工具(如 ESLint),都提供了强大的 JSX 语法检查和实时错误提示功能。它们可以在你输入代码时立即高亮显示未闭合的标签或语法错误,极大地减少了这类低级错误的发生。确保你的开发环境配置了相应的 JSX/React 插件和 Linter 规则。

总结

“JSX element 'X' has no corresponding closing tag.”是一个常见的、但很容易解决的 JSX 语法错误。核心在于理解并严格遵循 JSX 元素的开闭标签规则:带内容的元素必须使用完整的开闭标签对 内容,而无内容的元素则使用自闭合标签 。通过细致地编写代码、充分利用开发工具的辅助功能,并养成阅读和理解错误信息的习惯,可以有效避免此类问题,提升开发效率和代码质量。

Logo

以上就是解决 JSX 元素缺少闭合标签错误:理解 React/JSX 语法规范的详细内容,更多请关注其它相关文章!


# 这是一个  # 西湖公众号营销推广方案  # 泰安网站建设优化  # 镇江网站优化推荐公司  # 陕西营销宝推广版  # 小艳子同城推广网站下载  # 推广营销策划值多少钱  # 湖南抖音关键词搜索排名  # 首页seo优化  # 武清区公司营销推广电话  # 幼儿网站建设路推荐  # 服务端  # 抛出  # 不接受  # 行号  # 解决问题  # react  # 形如  # 开闭  # 自定义  # 错误信息  # 开发  # vs code  # 应用开发  # 工具  # webstorm  # go  # js  # html  # java  # javascript 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 126邮箱手机版登录官网2026_126手机邮箱免费入口最新  漫蛙漫画官方首页 漫蛙2漫画在线阅读入口  蛙漫官网漫画入口地址_蛙漫在线畅读无广告弹窗  C++ explicit关键字防止隐式转换_C++构造函数安全规范  深入理解Google Cloud Datastore查询:祖先路径与数据一致性  谷歌浏览器无痕模式怎么开 Chrome开启无痕浏览设置方法【教程】  mcjs网页版流畅运行 mcjs低配电脑畅玩入口  消息称三星明年 2 月正式发布 HBM4,与 SK 海力士同台竞技  Golang如何安装Swagger工具_GoSwagger文档生成环境  响应式图片在网页设计中的正确实现方法  初次安装JDK时环境变量如何正确配置_J*A_HOME与PATH设置规则讲解  html两个JS只运行一个怎么办_让双JS在html中都运行方法【技巧】  机构:以往存储涨价周期小米利润率实际上有所改善 能转嫁给消费者等  高德地图家和公司地址在哪设置 高德地图通勤路线设置方法【超详细】  晋江读书网页版在线登录 晋江读书电脑版官网  支付宝如何设置安全保护_支付宝安全设置的全面教程  如何设置Windows Defender的定时扫描_计划任务实现自动杀毒【安全】  如何在J*a中使用Locale处理多语言环境  批改网学生版PC登录 批改网官网登录系统入口  Golang如何使用new_Go new分配内存机制讲解  C++如何生成随机数_C++ random库使用方法与范围设置  如何在 Excel Online 和 Google 表格中更改日期格式  Archive of Our Own官网直达 AO3最新可用地址一览  PHP中高效并行检查多链接状态的教程  J*aScript中在Map循环中检测并处理空数组元素  中兴BladeV30怎样用测距估书架层高_iPhone中兴BladeV30测距估书架层高【家装参考】  Tailwind CSS line-clamp 布局问题解析与修复指南  React列表渲染与独立状态管理:避免全局状态影响局部更新  深入理解J*a链表中的IPosition接口与使用  在J*a中如何在J*a中使用异常机制记录错误日志_异常日志实践经验  AO3网页版合集入口 Archive of Our Own同人作品浏览指南  126邮箱网页版官方入口 126邮箱账号在线登录平台  CSS自定义字体样式被系统字体替换怎么办_font-face方式指定font-display控制渲染策略  Steam官网入口直达 Steam注册及登录步骤  在VS Code中配置和运行Dart程序的完整步骤  谷歌推RCS信息存档功能:公司可监控员工私密信息!  2025俄罗斯Yandex最新入口 官方网站地址及浏览器下载指南  C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入  学习通网页版快速入口 学习通官网网页版直接打开  windows10怎么查看硬盘序列号_windows10硬盘id查询命令  《马克思佩恩3》早期版本曝光 UI设计曾多次调整!  Yandex官网免登录入口_俄罗斯Yandex搜索引擎一键访问  内存疯狂猛猛涨价:主板销量直接腰斩!  KFC早餐时段怎么领特惠代码_KFC早餐订餐优惠代码获取与使用说明  Vue.js 图片显示异常排查:理解应用挂载范围与DOM ID唯一性  css子元素高度不一致导致布局错位怎么办_使用align-items:stretch解决高度差异  如何创建独立于主系统的J*a运行环境_隔离式环境搭建策略  抖音隐秘迷城小游戏入口_ 抖音冒险解谜小游戏秒玩  C++如何解决segmentation fault_C++段错误调试与原因分析  黑猫投诉统一入口官网 消费者权益保护投诉平台 

搜索