Sha*_*ane 5 javascript node.js npm node-modules reactjs
我在尝试为 React 应用程序运行“npm start”时遇到了一个错误。
我的应用程序在开发过程中基本上按照我的预期运行,但是我遇到了一个错误,需要我更新我的节点版本作为潜在的修复。我将 node 更新到 v16.13.2,并且还决定将 npm 更新到 v8.3.2。现在,当尝试运行 npm start 时,我收到以下错误。我还发现奇怪的是引用的文件不是来自我当前项目文件夹中的目录。
到目前为止我已经尝试过以下操作:
我想知道是否有人可以帮忙解决?
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)
一周后我终于找到了解决方案。
首先,我尝试重新安装旧版本的 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,现在我的应用程序已正确加载。
注意:我尝试更新原始项目中的反应依赖项,但仍然无法使其正常工作。但是,这个新项目可以使用我的旧代码和上面提到的更改。希望这可以帮助别人!
| 归档时间: |
|
| 查看次数: |
26176 次 |
| 最近记录: |