NPM 核心知识点:一份清晰易懂的复习指南

如果你正在学习 Node.js 或现代前端开发,那么 NPM (Node Package Manager) 就是你每天都要打交道的好朋友。它就像一个巨大的应用商店,只不过里面装的都是代码模块。

这篇指南会帮你快速梳理 NPM 最核心的知识点,让你一看就懂,一学就会。

一、 项目的诞生:三个关键文件

当我们开始一个新项目时,通常会用 NPM 来打下地基。这个过程会生成三个非常重要的东西:

  1. package.json:项目的"身份证"

    • 如何生成 :在项目文件夹里运行 npm init -y
    • 作用 :它是一个 JSON 文件,记录了项目的基本信息,比如项目名称、版本号,最重要的是,它会列出你的项目需要哪些第三方包(也就是依赖)。
  2. node_modules:项目的"大仓库"

    • 如何生成 :运行 npm install
    • 作用 :这是一个文件夹,NPM 会把 package.json 里记录的所有依赖包都下载到这里。你的代码能正常运行,就靠这个"仓库"里的模块。
  3. package-lock.json:项目的"版本锁"

    • 如何生成 :运行 npm install 时自动生成。
    • 作用 :这个文件的作用至关重要!它会精确记录 你当前安装的每一个包的具体版本号。这样,无论你或你的同事在任何时候、任何电脑上运行 npm install,都能保证安装的包版本是完全一致的,避免了很多不必要的麻烦。

小结npm init -y 创建身份证,npm install 根据身份证建仓库、上版本锁。


二、 两种最重要的"帮手":生产依赖 vs. 开发依赖

你的项目依赖可以分为两种,理解它们的区别非常关键。

我们可以用一个盖房子的比喻来理解:

  • 生产依赖 (dependencies)

    • 是什么 :它们是构成房子的砖头、水泥和钢筋。没有它们,你的线上应用就无法运行。
    • 例子react, vue, echarts, axios
    • 如何安装npm install 包名 (在现代版本中 --save 是默认的,可以不写)。
    • 记录位置package.json 文件的 dependencies 字段。
  • 开发依赖 (devDependencies)

    • 是什么 :它们是盖房子时用的脚手架、起重机和设计图纸。它们只在开发过程中帮助你,房子盖好后就会被拆掉,不会交给房主。
    • 例子vite, eslint, jest (构建工具、代码检查、测试工具)。
    • 如何安装npm install 包名 --save-dev (简写:npm install 包名 -D)。
    • 记录位置package.json 文件的 devDependencies 字段。

小结 :线上要用的装成生产依赖 ,只在开发时用的装成开发依赖 (-D)。

专业技巧 :当你在服务器上部署项目时,可以运行 npm install --production,这个命令只会安装生产依赖,让部署过程更快、更轻量。


三、 两种安装"地点":项目里 vs. 电脑里

  • 本地安装(项目里)

    • 这是默认 的安装方式,包会被安装到项目的 node_modules 文件夹里,只对当前项目有效。我们平时安装的 echartsreact 等都属于这种。
  • 全局安装(电脑里)

    • 如何安装npm install 包名 -g (-g 代表 global)。
    • 作用 :主要用来安装那些提供命令行工具的包,让你可以在电脑的任何位置使用它。
    • 例子nrm, nodemon, http-server
    • 安装位置:一个你电脑上的公共文件夹,所有项目共享。

小结 :大部分包都安装在项目里。只有那些需要在任何地方都能敲命令的工具,才需要全局安装 (-g)。


四、 两个提效"神器"

  1. nrm:网络"加速器"

    • 问题:NPM 的官方服务器在国外,有时下载速度很慢。

    • nrm 是什么:一个帮你快速切换 NPM 下载源的工具。

    • 使用四步曲

      1. npm install nrm -g ------ 全局安装 nrm。
      2. nrm ls ------ 查看所有可用的下载源列表。
      3. nrm test ------ 测试哪个源的速度最快。
      4. nrm use <名字> ------ 切换到最快的源(例如 nrm use taobao)。
  2. scripts:自定义"快捷键"

    • 是什么package.json 文件里有一个 scripts 字段,你可以在里面定义自己的命令别名。

    • 如何使用

      json 复制代码
      "scripts": {
        "dev": "vite",
        "build": "vite build"
      }
    • 如何运行 :在终端输入 npm run dev 就等同于输入 vite。这让启动和构建项目变得非常简单。

相关推荐
空中海1 天前
第七章:vue工程化与构建工具
前端·javascript·vue.js
zhensherlock1 天前
Protocol Launcher 系列:Trello 看板管理的协议自动化
前端·javascript·typescript·node.js·自动化·github·js
zhuà!1 天前
element的el-form提交校验没反应问题
前端·elementui
龙猫里的小梅啊1 天前
CSS(一)CSS基础语法与样式引入
前端·css
小码哥_常1 天前
从0到1,开启Android音视频开发之旅
前端
渔舟小调1 天前
P19 | 前端加密通信层 pikachuNetwork.js 完整实现
开发语言·前端·javascript
qq_12084093711 天前
Three.js 工程向:Draw Call 预算治理与渲染批处理实践
前端·javascript
不会聊天真君6471 天前
JavaScript基础语法(Web前端开发笔记第三期)
前端·javascript·笔记
IT_陈寒1 天前
SpringBoot自动配置这破玩意儿又坑我一次
前端·人工智能·后端