【发布时间】:2020-08-31 19:32:07
【问题描述】:
我刚刚升级了我的 react 应用程序以包含最新的 react 路由器 v5.2 以获得 useHistory 挂钩。事情一直很好,直到第二天早上我第一次重新启动。现在,当我使用 f5 启动调试会话时,我在名为 json3 的节点模块文件中遇到异常。 (顺便说一句,应用程序在纱线启动后在浏览器中运行正常。)例外是“SyntaxError:位置 1 的 JSON 中的意外标记”。代码是json3.js中的第186行:
186 parseSupported = !parse('"\t"');
我阅读了 json3 README.md,它说:“JSON 3 已弃用并且不再维护。请不要在新项目中使用它,并迁移现有项目改用本机 JSON.parse 和 JSON.stringify。JSON 3 是用于旧 JavaScript 平台的 JSON 填充。”我不知道这是如何安装的,我认为我不需要它。它没有在我的 package.json 中列出。它位于 node_modules 的顶层。如何删除它?
以防万一,我的 package.json 是这样的:
{
"name": "blue-duck-pwa",
"version": "0.1.0",
"private": true,
"devDependencies": {
"enzyme": "3.2.0",
"enzyme-adapter-react-16": "^1.1.0",
"eslint": "^6.8.0",
"eslint-config-prettier": "^6.10.0",
"eslint-plugin-react": "^7.18.3",
"faker": "^4.1.0",
"prettier": "2.0.1",
"react-scripts": "1.1.0",
"react-test-renderer": "16.0.0",
"redux-devtools": "^3.4.1",
"redux-devtools-dock-monitor": "1.1.4",
"redux-devtools-log-monitor": "2.0.1",
"redux-logger": "^3.0.6"
},
"dependencies": {
"add": "^2.0.6",
"base-64": "^0.1.0",
"bootstrap": "^3.3.7",
"chart.js": "2.9.3",
"cheerio": "0.19.x",
"file-saver": "^1.3.8",
"history": "^4.6.3",
"lodash": "^4.17.4",
"lodash.clonedeep": "^4.5.0",
"prop-types": "15.6.0",
"rc-dropdown": "^2.1.0",
"rc-menu": "^6.2.5",
"react": "16.13.0",
"react-auto-suggest": "^0.0.12",
"react-bootstrap": "0.32.0",
"react-chartjs-2": "2.6.4",
"react-dom": "16.13.0",
"react-notification-system": "0.2.16",
"react-portal": "^4.0.0",
"react-redux": "^5.0.6",
"react-router": "5.2.0",
"react-router-bootstrap": "0.25.0",
"react-router-dom": "5.2.0",
"react-scrollchor": "^4.2.1",
"react-sizes": "1.0.0",
"redux": "^3.7.2",
"redux-promise-middleware": "^5.0.0",
"redux-thunk": "^2.2.0",
"uuid": "^3.1.0",
"xml2js": "0.4.19"
},
"scripts": {
"start": "react-scripts start",
"build": "react-scripts build",
"test": "react-scripts test --env=jsdom",
"eject": "react-scripts eject"
}
}
【问题讨论】:
-
我在这里可能是错的,但我认为你可以先从你的 package.json 中删除它,然后删除你的 node_modules,然后是一个新的
npm install -
尝试删除你的 node_modules 文件夹,然后运行 npm install。
-
我只是尝试在没有node_module文件夹的情况下运行yarn install,并且在新的node_modules中再次添加了json3
-
@jagraj singh 通过消除和重试使用从 package.json 中删除的不同文件的纱线安装的过程,我看到将 json3 添加到 node_modules 的反应脚本。我原来的 react-scripts v1.1.0 做到了,最新的 react-scripts v3.4.3 也做到了。那么我能做什么呢?我需要反应脚本!
标签: reactjs react-router polyfills