首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >模块未找到错误:包路径。/cjs/react.Development不从包导出

模块未找到错误:包路径。/cjs/react.Development不从包导出
EN

Stack Overflow用户
提问于 2022-04-29 19:14:04
回答 1查看 1.3K关注 0票数 0

在Reactjs中编译代码时,我得到了以下错误。我刚接触过Reactjs。

代码语言:javascript
复制
Module not found: Error: Package path ./cjs/react.development is not exported from package /Users/mansi/letsgrowmore/to-do-list/my-react-app/node_modules/react (see exports field in /Users/mansi/letsgrowmore/to-do-list/my-react-app/node_modules/react/package.json)
ERROR in ./src/Components/Todolist.js 7:0-51
Module not found: Error: Package path ./cjs/react.development is not exported from package /Users/mansi/letsgrowmore/to-do-list/my-react-app/node_modules/react (see exports field in /Users/mansi/letsgrowmore/to-do-list/my-react-app/node_modules/react/package.json)


webpack compiled with 1 error
代码语言:javascript
复制
import React from 'react';
import useState from 'react/cjs/react.development';
import Todoform from './Todoform';

export default function TodoList() {
  const [todos, setTodos] = useState([]);
  const addTask = task => {
    if (!task.text) {
      return;
    }
    const newTodos = [task, ...todos];
    setTodos(newTodos);
  }

  return (
    <div>
      <Todoform addTask={addTask}></Todoform>
    </div>
  );
}

我尝试了npm更新,降级版本,但仍然相同的错误。

EN

回答 1

Stack Overflow用户

发布于 2022-04-30 03:10:56

代码中的问题是,您使用的是从未从React导入的函数。

要解决这个问题,您需要导入从React中使用的函数。

为此,我们将使用一种名为树抖动的导入技术。这基本上是从导入中获取特定函数/变量的使用,而不是获取所有内容,并且只使用少量的东西。该技术大大提高了速度,减小了束的尺寸。

在您的React文件中,替换这一行代码:

代码语言:javascript
复制
import React from "react";

在这方面:

代码语言:javascript
复制
import React, { useState } from "react";

这将从React库导入useState函数。

如果您使用function中的另一个函数(例如useEffect),那么您需要像导入useState一样导入它。

代码语言:javascript
复制
import React, { useState, useEffect } from "react";

基本上,每次您需要从React导入一个函数/变量时,用大括号(,)中的逗号({})分隔它。

总之,要解决这个问题,您需要导入正在使用的函数/变量。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/72062737

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档