0

0

修复React应用中“'jsx' must be in scope”错误指南

碧海醫心

碧海醫心

发布时间:2025-10-05 11:44:02

|

968人浏览过

|

来源于php中文网

原创

修复React应用中“'jsx' must be in scope”错误指南

本文旨在解决React应用中常见的“'jsx' must be in scope”错误。该错误通常源于JSX Pragma的误用,特别是在引入自定义JSX运行时(如Emotion的jsx函数)时,却未正确导入相应的JSX工厂函数。我们将深入探讨JSX Pragma的工作原理,解释错误产生的根本原因,并提供两种明确的解决方案:一是正确导入自定义JSX工厂函数,二是移除不必要的JSX Pragma以恢复默认的React JSX运行时。

理解JSX Pragma及其作用

react开发中,jsx允许我们在javascript代码中编写类似html的结构。然而,浏览器并不能直接理解jsx。在代码执行之前,jsx需要通过babel等工具进行转换。这个转换过程会将jsx元素编译成常规的javascript函数调用。

默认情况下,Babel会将JSX元素编译为React.createElement()函数的调用。例如,会被转换为React.createElement(MyComponent, null)。

/** @jsx pragma */ 是一种特殊的注释,被称为JSX Pragma。它指示Babel JSX转换插件使用哪个函数来编译JSX表达式,而不是默认的React.createElement。当你看到/** @jsx jsx */时,它告诉Babel将所有的JSX元素编译为对一个名为jsx的函数的调用,而不是React.createElement。

这种自定义JSX Pragma的场景通常出现在需要特定JSX运行时行为的库中,例如:

  • Emotion库的css prop: Emotion允许你使用css prop来直接在组件中定义样式。为了支持这种语法,它需要一个自定义的JSX运行时,通常是@emotion/react包提供的jsx函数。
  • Preact: Preact使用h函数来创建虚拟DOM节点,而不是React.createElement。

“'jsx' must be in scope”错误解析

当你在文件顶部添加了/** @jsx jsx */ Pragma,但没有在文件中导入名为jsx的函数时,就会触发“'jsx' must be in scope when using JSX”的ESLint警告或“jsx is not defined”的编译错误

  1. ESLint警告 (eslintreact/react-in-jsx-scope): ESLint在进行静态代码分析时,会识别到/** @jsx jsx */ Pragma。它知道这个Pragma意味着代码中将使用一个名为jsx的函数来处理JSX。如果ESLint发现这个jsx函数没有被导入到当前作用域中,它就会发出警告,提醒你可能存在潜在的运行时错误。
  2. 编译错误 (jsx is not defined): 即使你通过配置'react/react-in-jsx-scope': 'off'禁用了ESLint的警告,底层的问题依然存在。当Babel根据/** @jsx jsx */将JSX编译为jsx(...)调用时,如果运行时环境中没有定义jsx函数,JavaScript引擎就会抛出ReferenceError: jsx is not defined的错误,导致应用无法编译或运行。

简单来说,/** @jsx jsx */就像一个承诺,告诉编译器“我将提供一个名为jsx的函数来处理JSX”。如果你没有兑现这个承诺(即没有导入jsx),那么运行时就会出错。

解决方案

解决此问题主要有两种方法,取决于你的实际需求:

方案一:导入自定义JSX工厂函数 (当你确实需要自定义JSX运行时)

如果你正在使用像Emotion这样的库,并且明确需要其自定义的JSX运行时(例如,为了使用css prop),那么你必须从相应的包中导入jsx函数。

示例代码:

学习导航
学习导航

学习者优质的学习网址导航网站

下载
/** @jsx jsx */ // 告诉Babel使用jsx函数编译JSX
import { createContext, useContext, useState } from 'react';
import { jsx } from '@emotion/react'; // 关键:导入Emotion提供的jsx函数

interface MyContextType {
  isReady: boolean;
}

interface Props {
  children: React.ReactNode;
}

const MyContext = createContext({} as MyContextType);

export const MyContextProvider = ({ children }: Props) => {
  const [isReady, setIsReady] = useState(false);

  return (
    
      {children}
    
  );
};

// 示例用法 (假设某个组件需要使用Emotion的css prop)
const StyledDiv = () => (
  
这是一个使用Emotion样式化的div。
);

注意事项:

  • 确保你已经安装了对应的库(例如@emotion/react)。
  • import { jsx } from '@emotion/react'; 必须出现在使用/** @jsx jsx */ Pragma的文件的顶部,以便jsx函数在编译时和运行时都可用。

方案二:移除自定义JSX Pragma (当你不需要自定义JSX运行时)

如果你没有使用Emotion或其他需要自定义JSX运行时的库,或者你仅仅是错误地添加了/** @jsx jsx */ Pragma,那么最简单的解决方案就是将其删除。

通过删除/** @jsx jsx */,你将指示Babel恢复其默认行为,即使用React.createElement()来编译JSX。

示例代码:

// 移除了 /** @jsx jsx */ Pragma
import { createContext, useContext, useState } from 'react';
import React from 'react'; // 在旧版React或需要使用React Hooks/Context时仍需导入React

interface MyContextType {
  isReady: boolean;
}

interface Props {
  children: React.ReactNode;
}

const MyContext = createContext({} as MyContextType);

export const MyContextProvider = ({ children }: Props) => {
  const [isReady, setIsReady] = useState(false);

  return (
    
      {children}
    
  );
};

注意事项:

  • 在React 17及更高版本中,随着新的JSX转换(New JSX Transform)的引入,即使不导入React,JSX元素也能被编译。然而,如果你在组件中使用了React Hooks(如useState, useContext)或React Context,你仍然需要import React from 'react',因为这些API是React对象的一部分。
  • 这种方法适用于绝大多数标准的React应用。

总结与最佳实践

“'jsx' must be in scope”错误是一个清晰的信号,表明你的JSX Pragma配置与实际代码中的JSX运行时不匹配。解决这个问题的关键在于理解/** @jsx pragma */的作用以及它如何影响Babel的JSX编译过程。

  • 明确意图: 在使用/** @jsx pragma */之前,请明确你是否真的需要自定义JSX运行时。如果你只是在编写标准的React组件,通常不需要这个Pragma。
  • 保持一致性: 如果你使用了自定义Pragma(例如/** @jsx jsx */),请务必在同一文件中导入相应的JSX工厂函数(例如import { jsx } from '@emotion/react';)。
  • 避免禁用ESLint规则: 像'react/react-in-jsx-scope': 'off'这样的ESLint规则通常是为了捕获潜在的运行时错误。禁用它们只会隐藏问题,而不是解决问题。始终尝试理解并修复ESLint报告的根本原因。
  • 了解项目配置: 检查你的babel.config.js或webpack.config.js等构建配置,了解JSX是如何被转换的,这有助于诊断更复杂的JSX相关问题。

通过遵循这些指南,你可以有效地避免和解决React应用中与JSX Pragma相关的“'jsx' must be in scope”错误,确保代码的健壮性和可维护性。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

更多
c语言中null和NULL的区别
c语言中null和NULL的区别

c语言中null和NULL的区别是:null是C语言中的一个宏定义,通常用来表示一个空指针,可以用于初始化指针变量,或者在条件语句中判断指针是否为空;NULL是C语言中的一个预定义常量,通常用来表示一个空值,用于表示一个空的指针、空的指针数组或者空的结构体指针。

236

2023.09.22

java中null的用法
java中null的用法

在Java中,null表示一个引用类型的变量不指向任何对象。可以将null赋值给任何引用类型的变量,包括类、接口、数组、字符串等。想了解更多null的相关内容,可以阅读本专题下面的文章。

458

2024.03.01

js正则表达式
js正则表达式

php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

514

2023.06.20

js获取当前时间
js获取当前时间

JS全称JavaScript,是一种具有函数优先的轻量级,解释型或即时编译型的编程语言;它是一种属于网络的高级脚本语言,主要用于Web,常用来为网页添加各式各样的动态功能。js怎么获取当前时间呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

244

2023.07.28

js 字符串转数组
js 字符串转数组

js字符串转数组的方法:1、使用“split()”方法;2、使用“Array.from()”方法;3、使用for循环遍历;4、使用“Array.split()”方法。本专题为大家提供js字符串转数组的相关的文章、下载、课程内容,供大家免费下载体验。

298

2023.08.03

js是什么意思
js是什么意思

JS是JavaScript的缩写,它是一种广泛应用于网页开发的脚本语言。JavaScript是一种解释性的、基于对象和事件驱动的编程语言,通常用于为网页增加交互性和动态性。它可以在网页上实现复杂的功能和效果,如表单验证、页面元素操作、动画效果、数据交互等。

5326

2023.08.17

js删除节点的方法
js删除节点的方法

js删除节点的方法有:1、removeChild()方法,用于从父节点中移除指定的子节点,它需要两个参数,第一个参数是要删除的子节点,第二个参数是父节点;2、parentNode.removeChild()方法,可以直接通过父节点调用来删除子节点;3、remove()方法,可以直接删除节点,而无需指定父节点;4、innerHTML属性,用于删除节点的内容。

481

2023.09.01

js截取字符串的方法
js截取字符串的方法

js截取字符串的方法有substring()方法、substr()方法、slice()方法、split()方法和slice()方法。本专题为大家提供字符串相关的文章、下载、课程内容,供大家免费下载体验。

212

2023.09.04

java入门学习合集
java入门学习合集

本专题整合了java入门学习指南、初学者项目实战、入门到精通等等内容,阅读专题下面的文章了解更多详细学习方法。

1

2026.01.29

热门下载

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

精品课程

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

共14课时 | 0.8万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

CSS教程
CSS教程

共754课时 | 25万人学习

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

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