0

0

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

碧海醫心

碧海醫心

发布时间:2025-10-25 11:07:24

|

300人浏览过

|

来源于php中文网

原创

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

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

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

理解 JSX 元素闭合规则

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

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

    正确示例:

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

    正确示例:

    <img src="logo.png" alt="Logo" />
    <input type="text" placeholder="请输入..." />
    <MyComponent propA="value" /> {/* 假设 MyComponent 不接受 children */}

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

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

PatentPal专利申请写作
PatentPal专利申请写作

AI软件来为专利申请自动生成内容

下载

错误示例代码:

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

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

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

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

通过这次修改,<div> 元素现在有了正确的开标签和闭标签,符合 JSX 语法规范。

注意事项与开发实践

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

  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 元素的开闭标签规则:带内容的元素必须使用完整的开闭标签对 <TagName>内容</TagName>,而无内容的元素则使用自闭合标签 <TagName />。通过细致地编写代码、充分利用开发工具的辅助功能,并养成阅读和理解错误信息的习惯,可以有效避免此类问题,提升开发效率和代码质量。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.24

webstorm怎么放大
webstorm怎么放大

webstorm 提供四种放大代码编辑器的方法:键盘快捷键:ctrl/cmd + plus菜单:查看 > 缩放 > 放大工具栏:缩放按钮鼠标滚轮:按住 ctrl/cmd 滚动。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

301

2024.04.08

webstorm闪退怎么解决
webstorm闪退怎么解决

解决 webstorm 闪退问题的步骤:检查更新;重新启动计算机;禁用插件;重置设置;清除缓存;检查防火墙和防病毒软件;重新安装 webstorm;联系支持团队。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

298

2024.04.08

webstorm运行不了文件的原因
webstorm运行不了文件的原因

webstorm无法运行文件的原因:node.js 版本不匹配;文件路径错误;环境变量未设置;文件依赖项丢失;权限问题;防火墙拦截;webstorm 插件冲突;webstorm 错误。想了解更多webstorm的相关内容,可以阅读本专题下面的文章。

363

2024.04.08

webstorm调节字体大小
webstorm调节字体大小

可以通过三种方法调整 webstorm 的字体大小:快捷键(windows/linux:ctrl + alt + (+或-);macos:cmd + alt + (+或-))、菜单(文件 > 设置 > 外观与行为 > 外观 > ide 字体大小)、注册表(仅限 windowshkey_current_usersoftwarejetbrainswebstorm92.7785.53optionsedit

354

2024.04.08

webstorm创建html的方法
webstorm创建html的方法

webstorm创建html项目分五步:创建新项目并配置 html 设置;添加新 html 文件;编写 html 代码并利用实时预览;预览 html 文件并进行部署;使用模板和 emmet 快捷方式加快开发。想了解更多webstorm的相关内容,可以阅读本专题下面的文章。

386

2024.04.08

webstorm新建文件夹方法
webstorm新建文件夹方法

webstorm新建文件夹方法:在项目视图中导航到目标位置;右键单击并选择“新建”>“文件夹”;输入文件夹名称并单击“确定”。想了解更多webstorm的相关内容,可以阅读本专题下面的文章。

458

2024.04.08

webstorm启动项目方法
webstorm启动项目方法

启动方法:1、打开webstorm:启动 webstorm 应用程序;2、创建或打开项目:创建新项目或打开现有项目;3、配置项目:选择项目类型和解释器,配置其他项目设置;4、开始编码:创建文件并编写代码,webstorm 将自动提供代码功能;5、运行项目:右键单击相关文件并选择“启动文件”或“启动”。

414

2024.04.08

TypeScript类型系统进阶与大型前端项目实践
TypeScript类型系统进阶与大型前端项目实践

本专题围绕 TypeScript 在大型前端项目中的应用展开,深入讲解类型系统设计与工程化开发方法。内容包括泛型与高级类型、类型推断机制、声明文件编写、模块化结构设计以及代码规范管理。通过真实项目案例分析,帮助开发者构建类型安全、结构清晰、易维护的前端工程体系,提高团队协作效率与代码质量。

26

2026.03.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 6.1万人学习

国外Web开发全栈课程全集
国外Web开发全栈课程全集

共12课时 | 1万人学习

React核心原理新老生命周期精讲
React核心原理新老生命周期精讲

共12课时 | 1.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号