npx 与 npm 区别

一、 一句话总结区别

|-----|----------------------------|
| 工具 | 作用 |
| npm | 安装包(比如下载 `@angular/cli`) |
| npx | 执行包里的命令(比如运行 `ng` 命令) |

👉 就像:

`npm` 是"下载软件"

`npx` 是"运行软件"

二、详细对比

|---------|----------------------|------------------------------------|
| 特性 | npm | npx |
| 全称 | Node Package Manager | Node Package execute |
| 主要用途 | 安装、管理依赖包 | 执行包中的命令 |
| 是否需要先安装 | 是(`npm install`) | 否(可直接运行) |
| 执行命令 | ❌不能直接运行 `ng` | 可以运行 `ng`、`create-react-app` 等 |
| 自动安装 | ❌ | 如果没安装,会临时下载并运行 |

三、 举个实际例子

场景:你想创建一个 Angular 项目

❌ 旧方式(依赖全局安装)

bash 复制代码
npm install -g @angular/cli     # 先全局安装
ng new my-app                   # 再运行命令

问题:

  • 全局只能有一个版本

  • 容易版本冲突(比如你项目是 v15,但全局是 v10)

✅ 现代方式(使用 `npx`)

bash 复制代码
npx @angular/cli@latest new my-app

npx 会自动:

  1. 检查本地有没有 `@angular/cli`

  2. 没有?→ 临时下载 `@angular/cli@latest`

  3. 运行 `ng new my-app`

  4. 完成后可清理缓存

无需全局安装,每个项目用自己需要的版本。

四、 npx 的强大功能

  1. 无需全局安装,直接运行命令
bash 复制代码
npx create-react-app my-app
npx vue@3 create my-vue-app
npx http-server

这些命令都不需要你提前 `npm install -g`。

  1. 自动使用本地包(优先)

如果你的项目已经安装了 `@angular/cli`,运行:

bash 复制代码
npx ng serve

npx 会:

  • 先找 `node_modules/.bin/ng`

  • 找到就用本地的 CLI

  • 找不到才去下载

前提是:确保你用的是项目指定的版本~

  1. 临时运行某个版本的命令
bash 复制代码
npx @angular/cli@10 ng new old-project --strict=false
npx @angular/cli@15 ng new new-project

可以同时测试不同版本的 CLI,互不干扰。

  1. 运行一次性工具
bash 复制代码
npx serve                    # 启动一个静态服务器
npx cowsay "Hello!"          # 打印牛说话(趣味工具)
npx json-server --watch db.json  # 模拟 API

用完就走,不用安装。

五、 `npx` vs `npm run` 的区别

|---------------|-----------------------------------------------|
| 命令 | 说明 |
| npx ng serve | 直接执行 `ng` 命令(从本地或远程) |
| npm run serve | 执行 `package.json` 中定义的 `scripts.serve` 脚本 |

例如:

javascript 复制代码
"scripts": {
  "serve": "ng serve"
}

那么:

bash 复制代码
npm run serve

等价于:

bash 复制代码
npx ng serve

推荐在 `package.json` 中定义脚本,然后用 `npm run` 调用。

六、 最佳实践(推荐)

|-------|-------------------------------------|
| 场景 | 做法 |
| 创建新项目 | npx @angular/cli@latest new my-app |
| 启动项目 | npm run start`(或 `npx ng serve`) |
| 构建项目 | npm run build |
| 查看版本 | npx ng version |
| 临时工具 | npx http-server |

七、 总结

|----------------|-------------------------|
| 问题 | 回答 |
| npx 是什么 | 用来执行npm 包中的命令 |
| npx和 npm区别 | `npm` 是安装,`npx` 是运行 |
| 为什么要用 `npx`? | 避免全局安装、解决版本冲突、临时使用工具 |
| npx ng` 安全吗 | 安全,优先使用本地 CLI,不会受全局干扰 |

相关推荐
Highcharts.js4 小时前
Next.js 集成 Highcharts 官网文档说明(2025 新版)
开发语言·前端·javascript·react.js·开发文档·next.js·highcharts
总爱写点小BUG4 小时前
探索 vu-icons:一款轻量级、跨平台的 Vue3 & UniApp SVG 图标库
前端·前端框架·组件库
每天瞎忙的农民工4 小时前
Ubuntu 24 安装npm22
linux·运维·ubuntu·npm
晚霞的不甘4 小时前
Flutter for OpenHarmony手势涂鸦画板开发详解
前端·学习·flutter·前端框架·交互
We་ct5 小时前
LeetCode 73. 矩阵置零:原地算法实现与优化解析
前端·算法·leetcode·矩阵·typescript
晚霞的不甘5 小时前
Flutter for OpenHarmony 实现动态天气与空气质量仪表盘:从 UI 到动画的完整解析
前端·flutter·ui·前端框架·交互
~小仙女~5 小时前
组件的二次封装
前端·javascript·vue.js
这是个栗子5 小时前
AI辅助编程(一) - ChatGPT
前端·vue.js·人工智能·chatgpt
2501_944448005 小时前
Flutter for OpenHarmony衣橱管家App实战:预算管理实现
前端·javascript·flutter
Remember_9935 小时前
Spring 核心原理深度解析:Bean 作用域、生命周期与 Spring Boot 自动配置
java·前端·spring boot·后端·spring·面试