简介NPM 和 NPX

npm 和 npx的基本使用条件

  • NPM(Node Package Manager)是 Node.js 的包管理工具,用于安装、管理和发布 JavaScript 包。NPX 是 NPM 5.2.0 及以上版本附带的工具,用于临时执行包中的命令。
  • npx 是 npm(Node.js 包管理器)的一部分,因此需要安装 Node.js 环境才能使用。Node.js 的安装包默认会包含 npm 和 npx。
  • npx 在执行时会从 npm 仓库下载所需的包(如果本地未安装)。因此需要稳定的网络连接才能正常使用。

npx 的内部逻辑

npx 的工作原理可以分为以下几个关键步骤:

  1. 查找本地或全局包 npx 会先检查命令是否存在于本地项目的 node_modules/.bin 或全局安装的包中。如果找到,直接执行。

  2. 临时下载并执行 如果本地或全局未安装该包,npx 会从 npm 仓库下载包的最新版本(或指定版本),存放在临时目录中,执行后自动清理(除非使用 --no-clean 选项)。

  3. 缓存机制 下载的包会被缓存在系统的 npm 缓存目录中(如 ~/.npm/_npx),避免重复下载。缓存会保留一段时间,但不会永久存储。

  4. 执行环境隔离 npx 会为每次临时执行创建一个独立的上下文,确保不会污染项目依赖或全局环境。

  5. 支持远程脚本 npx 可以直接运行 GitHub Gist 或其他远程脚本,例如:

    复制代码
    npx https://gist.github.com/user/script.js

清理 npx 安装的包

npx 是 npm 5.2.0 及以上版本自带的工具,用于临时执行 npm 包中的命令。由于 npx 的设计目标是临时使用,它不会永久安装包到本地项目中。清理 npx 缓存或临时文件可以通过以下方法:

  1. 清理 npx 缓存 npx 会将下载的包缓存在系统中,可以通过以下命令清理缓存:

    复制代码
    npx clear-npx-cache

    或者直接删除 npm 的缓存目录(npx 共享 npm 的缓存):

    复制代码
    npm cache clean --force
  2. 手动删除临时文件 npx 的临时文件通常存储在系统的临时目录中,路径可能为:

    • Linux/macOS: /tmp~/.npm/_npx
    • Windows: %TEMP%C:\Users\<USER>\AppData\Local\npm-cache\_npx 可以直接删除这些目录中的文件。
  3. 定期清理 npm 缓存 由于 npx 依赖 npm 的缓存机制,定期运行以下命令可以清理旧文件:

    复制代码
    npm cache verify

NPM 和 NPX 的核心区别

NPM 的主要功能

NPM 主要用于包的安装和管理。通过 npm install 命令,可以将包下载到本地 node_modules 目录中,并在项目中引用。NPM 还支持版本控制、依赖管理和脚本执行(通过 package.json 中的 scripts 字段)。

  • 安装包
    npm install <package-name>

    将包安装到项目的 node_modules 目录中,并添加到 dependenciesdevDependencies

  • 全局安装
    npm install -g <package-name>

    将包安装到全局环境,供所有项目使用。

  • 运行脚本
    npm run <script-name>

    执行 package.json 中定义的脚本。


NPX 的主要功能

NPX 用于临时执行包中的命令,无需全局安装。它会在执行命令时检查本地 node_modules 和全局环境,如果未找到包,则自动下载并执行,执行完成后删除临时文件。

  • 临时执行包
    npx <package-name>

    无需全局安装即可运行包中的命令。

  • 执行本地未安装的包

    如果包未安装,NPX 会临时下载并执行,完成后清理。

  • 运行特定版本的包
    npx <package-name>@<version>

    指定包的版本运行。

  • 直接运行 GitHub 代码
    npx github:<username>/<repo>

    从 GitHub 仓库直接运行代码。


使用场景对比

  • NPM

    适合管理项目依赖,长期使用的包。例如,安装 reactlodash 等需要在项目中重复使用的库。

  • NPX

    适合一次性或临时任务。例如,快速运行脚手架工具(如 create-react-app)或测试某个包的功能。


示例对比

  1. 使用 NPM 运行 create-react-app

    需要先全局安装,再执行命令:

    bash 复制代码
    npm install -g create-react-app
    create-react-app my-app
  2. 使用 NPX 运行 create-react-app

    无需安装,直接执行:执行完命令之后 create-react-app包自动从缓存目录中清除

    bash 复制代码
    npx create-react-app my-app

总结

  • NPM 是包管理工具,用于安装和管理依赖。
  • NPX 是执行工具,用于临时运行包中的命令,避免全局安装的污染。
  • 在需要频繁使用某个包时,用 NPM 安装;在临时使用时,用 NPX 执行。
相关推荐
进阶小白猿7 小时前
Java技术八股学习Day36
学习
学嵌入式的小杨同学7 小时前
从零打造 Linux 终端 MP3 播放器!用 C 语言实现音乐自由
linux·c语言·开发语言·前端·vscode·ci/cd·vim
weixin_425543738 小时前
TRAE CN3.3.25 构建的Electron简易DEMO应用
前端·typescript·electron·vite·nestjs
Mr Xu_9 小时前
【Vue3 + ECharts 实战】正确使用 showLoading、resize 与 dispose 避免内存泄漏
前端·信息可视化·vue·echarts
四维碎片9 小时前
【Qt】UDP跨平台调试工具
qt·学习·udp
朝朝暮暮an9 小时前
Day 2|Node.js 运行机制、模块系统与异步初探
node.js
0思必得09 小时前
[Web自动化] Selenium设置相关执行文件路径
前端·爬虫·python·selenium·自动化
雯0609~9 小时前
hiprint:实现项目部署与打印1-官网提供普通html版本
前端·html
好奇龙猫9 小时前
【人工智能学习-AI入试相关题目练习-第十八次】
人工智能·学习
程序员辣条9 小时前
AI产品经理:2024年职场发展的新机遇
人工智能·学习·职场和发展·产品经理·大模型学习·大模型入门·大模型教程