npm install 返回“TypeError:无法将未定义或 null 转换为对象”

问题描述 投票:0回答:6

我正在尝试使用

npm install -g eslint
全局安装 eslint。这是使用 nvm 安装的 [email protected]/[email protected] 的新版本。我收到的错误是:

堆栈跟踪:

0 info it worked if it ends with ok
1 verbose cli [ '/Users/fitvalet/.nvm/versions/node/v7.2.1/bin/node',
1 verbose cli   '/Users/fitvalet/.nvm/versions/node/v7.2.1/bin/npm',
1 verbose cli   'install',
1 verbose cli   '-g',
1 verbose cli   'eslint' ]
2 info using [email protected]
3 info using [email protected]
4 silly loadCurrentTree Starting
5 silly install loadCurrentTree
6 silly install readGlobalPackageData
7 silly fetchPackageMetaData eslint
8 silly fetchNamedPackageData eslint
9 silly mapToRegistry name eslint
10 silly mapToRegistry using default registry
11 silly mapToRegistry registry http://skimdb.npmjs.com/registry
12 silly mapToRegistry data Result {
12 silly mapToRegistry   raw: 'eslint',
12 silly mapToRegistry   scope: null,
12 silly mapToRegistry   escapedName: 'eslint',
12 silly mapToRegistry   name: 'eslint',
12 silly mapToRegistry   rawSpec: '',
12 silly mapToRegistry   spec: 'latest',
12 silly mapToRegistry   type: 'tag' }
13 silly mapToRegistry uri http://skimdb.npmjs.com/registry/eslint
14 verbose request uri http://skimdb.npmjs.com/registry/eslint
15 verbose request no auth needed
16 info attempt registry request try #1 at 1:59:17 PM
17 verbose request id 066241c6e4150db4
18 http request GET http://skimdb.npmjs.com/registry/eslint
19 http 200 http://skimdb.npmjs.com/registry/eslint
20 verbose headers { 'cache-control': 'must-revalidate',
20 verbose headers   connection: 'close',
20 verbose headers   'content-type': 'application/json',
20 verbose headers   date: 'Tue, 13 Dec 2016 18:59:17 GMT',
20 verbose headers   server: 'CouchDB/2.0.0 (Erlang OTP/R16B03)',
20 verbose headers   'transfer-encoding': 'chunked',
20 verbose headers   'content-encoding': 'gzip',
20 verbose headers   'strict-transport-security': 'max-age=2592000000; includeSubDomains; preload;' }
21 silly get cb [ 200,
21 silly get   { 'cache-control': 'must-revalidate',
21 silly get     connection: 'close',
21 silly get     'content-type': 'application/json',
21 silly get     date: 'Tue, 13 Dec 2016 18:59:17 GMT',
21 silly get     server: 'CouchDB/2.0.0 (Erlang OTP/R16B03)',
21 silly get     'transfer-encoding': 'chunked',
21 silly get     'content-encoding': 'gzip',
21 silly get     'strict-transport-security': 'max-age=2592000000; includeSubDomains; preload;' } ]
22 verbose get saving undefined to /Users/fitvalet/.npm/skimdb.npmjs.com/registry/eslint/.cache.json
23 verbose correctMkdir /Users/fitvalet/.npm correctMkdir not in flight; initializing
24 verbose makeDirectory /Users/fitvalet/.npm creation not in flight; initializing
25 silly makeDirectory /Users/fitvalet/.npm uid: 501 gid: 20
26 verbose stack TypeError: Cannot convert undefined or null to object
26 verbose stack     at Function.keys (<anonymous>)
26 verbose stack     at pickVersionFromRegistryDocument (/Users/fitvalet/.nvm/versions/node/v7.2.1/lib/node_modules/npm/lib/fetch-package-metadata.js:125:29)
26 verbose stack     at /Users/fitvalet/.nvm/versions/node/v7.2.1/lib/node_modules/npm/node_modules/iferr/index.js:13:50
26 verbose stack     at /Users/fitvalet/.nvm/versions/node/v7.2.1/lib/node_modules/npm/lib/utils/pulse-till-done.js:20:8
26 verbose stack     at saved (/Users/fitvalet/.nvm/versions/node/v7.2.1/lib/node_modules/npm/lib/cache/caching-client.js:174:7)
26 verbose stack     at /Users/fitvalet/.nvm/versions/node/v7.2.1/lib/node_modules/npm/node_modules/graceful-fs/polyfills.js:241:18
26 verbose stack     at FSReqWrap.oncomplete (fs.js:111:15)
27 verbose cwd /Users/fitvalet
28 error Darwin 16.1.0
29 error argv "/Users/fitvalet/.nvm/versions/node/v7.2.1/bin/node" "/Users/fitvalet/.nvm/versions/node/v7.2.1/bin/npm" "install" "-g" "eslint"
30 error node v7.2.1
31 error npm  v3.10.10
32 error Cannot convert undefined or null to object
33 error If you need help, you may report this error at:
33 error     <https://github.com/npm/npm/issues>
34 verbose exit [ 1, true ]
node.js npm npm-install nvm
6个回答
3
投票

问题是我有一个旧的.npmrc,它指向使用skimdb.npmjs.org的npm注册表。我删除了该文件,我的模块现在安装正常。

我可以通过输入

npm config list registry
来检查注册表,它现在指向我认为的默认值:https://registry.npmjs.org/


1
投票

很奇怪,但我刚刚将 npm 从 8.5.2 降级到 6.14.16,一切都开始工作了。


0
投票

问题出在 npm 注册表上 运行这个:

npm config get registry

并查看它是否设置为所需的 URI 默认注册表应设置为 https://registry.npmjs.org


0
投票

Webstorm 可以使用以下配置调试 npm cli:

添加 npm cli opt

--loglevel verbose
以显示错误堆栈跟踪详细信息

在 webstorm 中在堆栈跟踪行中设置断点以查找导致此错误的原因

就我而言,错误是由 package.json 中的 dep 引起的


0
投票

有同样的问题

npm install

我通过

npm install --legacy-peer-deps

获得了更好的结果

当然,如果你不想要这个选项,这对你来说并不好。


0
投票

这主要是因为互联网连接速度不佳。 您可以尝试以下方法使其正常工作

npm install --prefer-offline --no-audit

其次,您可以添加项目 .npmrc 文件并添加以下行

fetch-retry-maxtimeout = 6000000
fetch-retry-mintimeout = 1000000

你也可以尝试 npm 配置设置超时 6000000

© www.soinside.com 2019 - 2024. All rights reserved.