为啥在运行 npm update 时不是所有节点包都更新到最新版本?
Posted
技术标签:
【中文标题】为啥在运行 npm update 时不是所有节点包都更新到最新版本?【英文标题】:Why aren't all node packages updated to the latest version when running npm update?为什么在运行 npm update 时不是所有节点包都更新到最新版本? 【发布时间】:2019-07-29 00:27:44 【问题描述】:环境
Windows 10 家庭版 节点 v10.13.0 NPM 6.4.1
期望的行为
更新所有节点包。
实际行为
并非所有软件包都在更新。
我的尝试
npm update
根据这篇文章中的信息:
npm install vs. update - what's the difference?
运行前npm update
:
$ npm outdated
Package Current Wanted Latest Location
babel-loader 7.1.4 7.1.5 8.0.5 my_folder
bcrypt 3.0.0 3.0.4 3.0.4 my_folder
body-parser 1.18.2 1.18.3 1.18.3 my_folder
clipboard 2.0.1 2.0.4 2.0.4 my_folder
cors 2.8.4 2.8.5 2.8.5 my_folder
css-loader 0.28.11 0.28.11 2.1.0 my_folder
date-fns 1.29.0 1.30.1 1.30.1 my_folder
dompurify 1.0.8 1.0.10 1.0.10 my_folder
express 4.16.3 4.16.4 4.16.4 my_folder
file-loader 1.1.11 1.1.11 3.0.1 my_folder
file-saver 1.3.8 1.3.8 2.0.1 my_folder
helmet 3.13.0 3.15.1 3.15.1 my_folder
hotkeys-js 3.3.8 3.4.4 3.4.4 my_folder
jsonwebtoken 8.2.1 8.5.0 8.5.0 my_folder
less 3.0.4 3.9.0 3.9.0 my_folder
mongodb 3.1.6 3.1.13 3.1.13 my_folder
nodemailer 4.6.8 4.7.0 5.1.1 my_folder
socket.io 2.1.1 2.2.0 2.2.0 my_folder
style-loader 0.21.0 0.21.0 0.23.1 my_folder
uglifyjs-webpack-plugin 1.2.5 1.3.0 2.1.2 my_folder
uikit 3.0.0-rc.24 3.0.3 3.0.3 my_folder
url-loader 1.0.1 1.1.2 1.1.2 my_folder
validator 10.8.0 10.11.0 10.11.0 my_folder
webpack 4.19.1 4.29.6 4.29.6 my_folder
webpack-cli 2.1.5 2.1.5 3.2.3 my_folder
package.json
运行前npm update
:
"dependencies":
"bcrypt": "^3.0.0",
"body-parser": "^1.18.2",
"clipboard": "^2.0.1",
"cors": "^2.8.4",
"date-fns": "^1.29.0",
"dompurify": "^1.0.8",
"express": "^4.16.3",
"file-saver": "^1.3.8",
"helmet": "^3.13.0",
"hotkeys-js": "^3.3.8",
"jquery": "^3.3.1",
"js-cookie": "^2.2.0",
"jsonwebtoken": "^8.2.1",
"markdown-it": "^8.4.2",
"markdown-it-attrs": "^2.3.2",
"mongodb": "^3.1.6",
"nodemailer": "^4.6.8",
"rename-keys": "^2.0.1",
"socket.io": "^2.1.1",
"validator": "^10.8.0"
,
"devDependencies":
"babel-cli": "^6.26.0",
"babel-core": "^6.26.3",
"babel-loader": "^7.1.4",
"babel-preset-env": "^1.7.0",
"babel-preset-stage-0": "^6.24.1",
"css-loader": "^0.28.11",
"expose-loader": "^0.7.5",
"file-loader": "^1.1.11",
"less": "^3.0.4",
"less-loader": "^4.1.0",
"style-loader": "^0.21.0",
"uglifyjs-webpack-plugin": "^1.2.5",
"uikit": "^3.0.0-rc.24",
"url-loader": "^1.0.1",
"webpack": "^4.19.1",
"webpack-cli": "^2.1.5"
运行后npm update
:
$ npm outdated
Package Current Wanted Latest Location
babel-loader 7.1.5 7.1.5 8.0.5 my_folder
css-loader 0.28.11 0.28.11 2.1.0 my_folder
file-loader 1.1.11 1.1.11 3.0.1 my_folder
file-saver 1.3.8 1.3.8 2.0.1 my_folder
nodemailer 4.7.0 4.7.0 5.1.1 my_folder
style-loader 0.21.0 0.21.0 0.23.1 my_folder
uglifyjs-webpack-plugin 1.3.0 1.3.0 2.1.2 my_folder
webpack-cli 2.1.5 2.1.5 3.2.3 my_folder
为什么在运行npm update
时这些包没有更新到最新版本?
如何将它们更新到最新版本?
上下文
我已经离开一个开发项目大约 3 个月了,尝试在本地机器上运行 npm start
时出现错误:
Error: EPERM: operation not permitted, open 'C:\Users\Me\AppData\Roaming\npm\node_modules\nodemon\node_modules\flatmap-stream\index.min.js'
event‑stream
节点包似乎被“劫持”(参见相关的github issue here)。
我的杀毒程序Bitdefender确实删除了有问题的文件:
Item was deleted.
Threat name:
***.Agent.DQGP.
C:\Users\Me\AppData\Roaming\npm\node_modules\nodemon\node_modules\flatmap-stream\index.min.js
所以我决定更新所有节点包,希望有问题的包会被删除并更新到最新的“干净”版本。
【问题讨论】:
【参考方案1】:它的行为符合预期。
如果您查看您提到的“未更新”的软件包,并在您的package.json
中参考它们各自的条目,您会看到它们以^
(插入符号运算符)为前缀,这将仅将它们更新到最新的主要版本(第一个数字)。
例如,如果您使用包 babel-loader
,您的 package.json 将带有版本 "^7.1.4"
标记。 babel-loader
的 ^7.X.X 的最新主要版本是 => 7.1.5
您可以在此处查看(babel-loader
的)版本历史 => https://www.npmjs.com/package/babel-loader/v/8.0.0-beta.1
以上内容适用于您的package.json中所有以^开头的其他包,例如,
css-loader
file-loader
file-saver
nodemailer
style-loader
uglifyjs-webpack-plugin
webpack-cli
希望这会有所帮助!
【讨论】:
以上是关于为啥在运行 npm update 时不是所有节点包都更新到最新版本?的主要内容,如果未能解决你的问题,请参考以下文章
为啥我的 decipher.update 返回一个函数而不是解密的文本?节点JS