React - 错误:尝试运行 npm start 时找不到模块 React

Sha*_*ane 5 javascript node.js npm node-modules reactjs

我在尝试为 React 应用程序运行“npm start”时遇到了一个错误。

我的应用程序在开发过程中基本上按照我的预期运行,但是我遇到了一个错误,需要我更新我的节点版本作为潜在的修复。我将 node 更新到 v16.13.2,并且还决定将 np​​m 更新到 v8.3.2。现在,当尝试运行 npm start 时,我收到以下错误。我还发现奇怪的是引用的文件不是来自我当前项目文件夹中的目录。

到目前为止我已经尝试过以下操作:

  1. 删除 package-lock.json 和 node_modules 文件夹,然后使用 npm install 重新安装。
  2. 重新启动我的电脑。
  3. npm 安装反应脚本。

我想知道是否有人可以帮忙解决?

    node:internal/modules/cjs/loader:936
  throw err;
  ^

    Error: Cannot find module 'react'
    Require stack:
     - C:\Users\shane\AppData\Roaming\npm\node_modules\react-scripts\scripts\start.js
        at Function.Module._resolveFilename (node:internal/modules/cjs/loader:933:15)
        at Function.resolve (node:internal/modules/cjs/helpers:108:19)
        at Object.<anonymous> (C:\Users\shane\AppData\Roaming\npm\node_modules\react-scripts\scripts\start.js:52:31)
        at Module._compile (node:internal/modules/cjs/loader:1101:14)
        at Object.Module._extensions..js (node:internal/modules/cjs/loader:1153:10)
        at Module.load (node:internal/modules/cjs/loader:981:32)
        at Function.Module._load (node:internal/modules/cjs/loader:822:12)
        at Function.executeUserEntryPoint [as runMain] (node:internal/modules/run_main:81:12)
        at node:internal/main/run_main_module:17:47 {
      code: 'MODULE_NOT_FOUND',
      requireStack: [
        'C:\\Users\\shane\\AppData\\Roaming\\npm\\node_modules\\react-scripts\\scripts\\start.js'
      ]
    }
Run Code Online (Sandbox Code Playgroud)

包.json

    {
  "name": "faucet",
  "version": "0.1.0",
  "private": true,
  "dependencies": {
    "babel-eslint": "^10.0.2",
    "babel-polyfill": "6.26.0",
    "babel-preset-env": "1.7.0",
    "babel-preset-es2015": "6.24.1",
    "babel-preset-stage-2": "6.24.1",
    "babel-preset-stage-3": "6.24.1",
    "babel-register": "6.26.0",
    "@babel/eslint-parser": "^7.5.4",
    "@metamask/detect-provider": "^1.2.0",
    "@testing-library/jest-dom": "^5.16.1",
    "@testing-library/react": "^12.1.2",
    "@testing-library/user-event": "^13.5.0",
    "@truffle/contract": "^4.4.5",
    "@truffle/hdwallet-provider": "^2.0.0",
    "bulma": "^0.9.3",
    "ganache-cli": "^6.12.2",
    "node-fetch": "^2.6.7",
    "react": "^17.0.2",
    "react-dom": "^17.0.2",
    "react-scripts": "^4.0.3",
    "solc": "^0.8.11",
    "truffle": "^5.4.29",
    "web-vitals": "^2.1.3",
    "web3": "^1.7.0"
  },
  "scripts": {
    "start": "react-scripts start",
    "build": "react-scripts build",
    "test": "react-scripts test",
    "eject": "react-scripts eject"
  },
  "eslintConfig": {
    "extends": [
      "react-app",
      "react-app/jest"
    ]
  },
  "browserslist": {
    "production": [
      ">0.2%",
      "not dead",
      "not op_mini all"
    ],
    "development": [
      "last 1 chrome version",
      "last 1 firefox version",
      "last 1 safari version"
    ]
  }
}
Run Code Online (Sandbox Code Playgroud)

在此输入图像描述

Sha*_*ane 5

一周后我终于找到了解决方案。

首先,我尝试重新安装旧版本的 Node 和 npm,但这并没有解决我的问题。然后我重新安装了上面提到的版本。

不知何故,我的项目被损坏了,可能是因为我在 Node/NPM 打开时更新了它。然后我尝试将我的代码转移到一个新的 create-react-app 中。完成此操作后,我转到 package.json 文件夹,发现我的最后一步是使用我的依赖项中的 React 版本。

我使用的反应版本( "react": "^17.0.2")与我在项目中使用的很多节点模块不兼容,这导致它们在NPM中找不到。

我可以通过更新到 package.json 文件的依赖项中的以下内容来恢复到旧版本的 React 来解决此问题:

"react": "^16.13.0",
"react-dom": "^16.13.0",
"react-scripts": "4.0.3"
Run Code Online (Sandbox Code Playgroud)

完成此操作后,我保存并在终端中安装了 NPM,现在我的应用程序已正确加载。

注意:我尝试更新原始项目中的反应依赖项,但仍然无法使其正常工作。但是,这个新项目可以使用我的旧代码和上面提到的更改。希望这可以帮助别人!