全栈程序员-前端第一节-npm 是什么?

npm = Node Package Manager(Node 包管理器)

简单理解

npm 是 JavaScript/Node.js 的包管理工具,用于:

  • 安装和管理 JavaScript 库/工具
  • 管理项目依赖
  • 运行项目脚本

类比理解

  • npm ≈ Python 的 pip、Java 的 Maven、Go 的 go mod
  • npm 仓库 ≈ 应用商店(存放各种 JavaScript 包)

npm 的主要功能

1. 安装包
复制代码
npm install vite        # 安装 vite 包
npm install react       # 安装 react 库
npm install -D typescript  # 安装开发依赖(-D 表示 devDependencies)
2. 管理项目依赖

项目中的 package.json 文件记录依赖:

复制代码
{
  "name": "my-project",
  "dependencies": {
    "react": "^18.0.0",      // 生产依赖
    "vite": "^5.0.0"
  },
  "devDependencies": {
    "typescript": "^5.0.0"   // 开发依赖
  }
}
3. 运行脚本

在 package.json 中定义脚本:

复制代码
{
  "scripts": {
    "dev": "vite",
    "build": "vite build"
  }
}

然后运行:

npm run dev # 执行 scripts.dev 中的命令

npm run build # 执行 scripts.build 中的命令

npm 的组成部分

  1. npm 命令行工具:安装 Node.js 时自带
  1. npm 仓库:https://www.npmjs.com(全球最大的 JavaScript 包仓库)
  1. package.json:项目配置文件
  1. node_modules:存放已安装的包

常见 npm 命令

复制代码
npm install          # 安装 package.json 中的所有依赖
npm install <包名>    # 安装指定包
npm uninstall <包名>  # 卸载包
npm run <脚本名>      # 运行 package.json 中的脚本
npm init             # 初始化项目,创建 package.json
npm list             # 查看已安装的包
npm update           # 更新包

npm 与 Node.js 的关系

  • Node.js:JavaScript 运行时环境
  • npm:Node.js 自带的包管理器
  • 安装 Node.js 时会自动安装 npm

实际例子

当你创建一个前端项目时:

复制代码
# 1. 初始化项目
npm init -y

# 2. 安装 Vite
npm install -D vite

# 3. 在 package.json 中添加脚本
# "scripts": { "dev": "vite" }

# 4. 运行开发服务器
npm run dev

文件位置:package.json

它们位于 package.json 文件的 scripts 字段中。示例:

复制代码
{
  "name": "@vitejs/test-wasm",
  "private": true,
  "version": "0.0.0",
  "type": "module",
  "scripts": {                    ← scripts 字段开始
    "dev": "vite",                ← "dev" 在这里,第 7 行
    "build": "vite build",        ← "build" 在这里,第 8 行
    "preview": "vite preview"
  }                               ← scripts 字段结束
}

下一节vite学习 全栈程序员-前端第二节- vite是什么?-CSDN博客

相关推荐
donecoding1 小时前
一个 sudo 引发的血案:npm 全局包权限错乱彻底修复
前端·node.js·前端工程化
风骏时光牛马1 小时前
Raku正则匹配与数据批量处理实操案例
前端
nbwenren1 小时前
2026实测:Gemini 3 镜像站视觉能力实践——拍照原型图,一键生成 HTML+CSS 代码
前端·css·html
Lee川1 小时前
Prisma 实战指南:像搭积木一样设计古诗词数据库
前端·数据库·后端
jinanwuhuaguo2 小时前
(第二十九篇)OpenClaw 实时与具身的跃迁——从异步孤岛到数字世界的“原住民”
前端·网络·人工智能·重构·openclaw
广州华水科技2 小时前
深度测评2026年单北斗GNSS位移监测系统推荐,与高口碑变形监测设备一同引领行业新风尚
前端
Alice-YUE3 小时前
【js高频八股】防抖与节流
开发语言·前端·javascript·笔记·学习·ecmascript
是上好佳佳佳呀4 小时前
【前端(十一)】JavaScript 语法基础笔记(多语言对比)
前端·javascript·笔记
CDN3604 小时前
排查实录:网站偶发502/504错误?360CDN回源超时配置与日志分析技巧
前端·数据库