npm:详细解释前端项目开发前奏!!

当我们在终端输入 npm init vitenpm installnpm run dev等命令时,不禁会疑惑为什么要输入这些内容?这些内容能干什么?这些内容有什么用?

比如,当我们在终端输入npm init vite时,会触发以下行为:

我们能看到,似乎是下载了什么东西,然后需要给这个project命名。npx是什么?create-vite是什么?

命令执行的过程

实际上,当我们输入npm init vite时,终端会先执行npx命令,再执行create-vite,这表明npm正在使用npx来执行包,实际执行的是create-vite包。

npm(Node Package Manager)是什么?

npm中文文档介绍:npm 是 Node JavaScript 平台的包管理器。它将模块放置到位,以便 node 可以找到它们,并智能地管理依赖冲突。它具有极强的可配置性,可以支持各种用例。最常见的是,您使用它来发布、发现、安装和开发 node 程序

npx((Node Package eXecute)是什么?

npx是npm 5.2+ 版本中引入的包执行工具,用于执行npm包中的可执行文件。这里执行的是create-vite包。

所以

bash 复制代码
npm init vite
# ↓ 等价于
npx create-vite

vite是什么?

Vite是一个现代化的前端构建工具,由Vue.js作者尤雨溪开发,专为现代Web开发而设计。

Vite的核心特点有:
  • 极快的开发服务器
  • 闪电般的热模块替换(HMR)
  • 优化的生产构建
Vite的工作原理

开发环境 vs 传统打包工具

传统打包工具(如Webpack):

text 复制代码
源文件 → 全量打包 → Bundle → 开发服务器
   ↓
启动慢 (需要打包所有文件)

Vite的方式:

text 复制代码
源文件 → 按需加载 → 原生ESM → 浏览器
   ↓  
启动快 (无需预打包)
Vite支持的技术栈
  • 多框架支持,如Vue.js,React,Preact等
  • TypeScript原生支持
  • CSS预处理器

所以,我们知道了,当我们执行npm init vite时,npm会使用npx来执create-vite的包。进入create-vite包的工作流程。

我们先给Project按默认命名。

随后让我们选择框架,我们选择React

接着,选择一个变体。我们选择JavaScript

随后,就会创建项目目录并复制包含依赖配置,Vite配置,HTML入口,源码目录以及静态资源目录等文件。 如下:

text 复制代码
my-vite-project/
├── index.html           # 入口HTML (在根目录!)
├── vite.config.js       # Vite配置文件
├── package.json         # 依赖管理
├── src/                 # 源码目录
│   ├── main.js         # 应用入口
│   ├── App.vue         # 根组件
│   ├── components/     # 组件目录
│   └── assets/         # 静态资源
└── public/             # 公共静态文件

然后,我们就可以根据命令切换到项目目录,执行npm installnpm run dev 命令。

安装项目依赖包

当我们执行:

bash 复制代码
npm install

会读取package.json(依赖管理)文件,并从npm registry在线数据库)下载所有依赖,并创建node_modules将依赖安装到node_modules/目录下,生成package-lock.json锁定依赖版本。

启动开发服务器

最后,我们就可以执行npm run dev来启动开发服务器。

启动开发服务器会先查找脚本,在package.json中找到dev脚本,然后运行vite命令,启动服务器(通常在http://localhost:5173) 并会实时监听文件变化。

之后开发者,即可在src目录下完成项目开发。

相关推荐
爱学习的程序媛1 小时前
【Web前端】JavaScript设计模式全解析
前端·javascript·设计模式·web
小码哥_常1 小时前
从SharedPreferences到DataStore:Android存储进化之路
前端
老黑1 小时前
开源工具 AIDA:给 AI 辅助开发加一个数据采集层,让 AI 从错误中自动学习(Glama 3A 认证)
前端·react.js·ai·nodejs·cursor·vibe coding·claude code
jessecyj2 小时前
Spring boot整合quartz方法
java·前端·spring boot
苦瓜小生2 小时前
【前端】|【js手撕】经典高频面试题:手写实现function.call、apply、bind
java·前端·javascript
天若有情6732 小时前
前端HTML精讲03:页面性能优化+懒加载,搞定首屏加速
前端·性能优化·html
踩着两条虫2 小时前
AI驱动的Vue3应用开发平台深入探究(十):物料系统之内置组件库
android·前端·vue.js·人工智能·低代码·系统架构·rxjava
swipe3 小时前
AI 应用里的 Memory,不是“保存聊天记录”,而是管理上下文预算
前端·llm·agent
慧一居士3 小时前
nuxt3 项目和nuxt4 项目区别和对比
前端·vue.js
威联通安全存储3 小时前
破除“重前端、轻底层”的数字幻象:如何夯实工业数据的物理底座
前端·python