npm run dev 做了什么❓小白也能看懂

大家在做前端项目时,肯定经常用npm run dev这个命令来启动本地开发服务器吧?但你有没有想过,当我们输入这行命令后,背后到底发生了什么呢?

从package.json说起

在我们项目的package.json文件里,通常会有这样的配置:

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

看起来npm run dev就是执行了vite这个命令。但如果你直接在命令行里输入vite,通常会提示"命令未找到"。这是为什么呢?

秘密藏在node_modules里

答案就在项目根目录的node_modules文件夹中。当我们安装依赖包时,npm会在这里创建很多文件夹,其中就包括vite包。

vite包的package.json文件中,有一个重要的配置项bin

json 复制代码
{
  "bin": {
    "vite": "bin/vite.js"
  }
}

这告诉npm:"当你看到有人想运行vite命令时,就去执行bin/vite.js这个文件"。

跨平台的秘密

有趣的是,在vite包的bin目录下,我们实际上会看到三个文件:

  • vite(没有后缀,适用于Unix/Linux系统)
  • vite.cmd(适用于Windows系统)
  • vite.ps1(适用于PowerShell)

这是因为不同操作系统使用不同的脚本语言。npm很聪明,它会根据你当前的操作系统,自动选择正确的文件来执行。

对于Unix/Linux系统,它会使用一个shell脚本;对于Windows,它会使用.cmd文件;对于PowerShell用户,它会使用.ps1文件。

执行流程全解析

所以,整个npm run dev的执行过程是这样的:

  1. 你在终端输入npm run dev
  2. npm去查看package.json中的scripts配置,发现dev对应的是"vite"
  3. npmnode_modules/.bin目录下寻找vite命令
  4. 根据你的操作系统,选择正确的脚本文件执行
  5. 这个脚本文件最终会调用node.js来运行viteJavaScript代码
  6. 你的开发服务器就启动起来了!

如果本地没有怎么办?

如果项目本地没有安装vitenpm会去全局安装的包中寻找。如果你也没有全局安装,那么就会看到我们熟悉的"command not found"错误提示。

总结

简单来说,npm run dev实际上是通过npm执行了一个"快捷方式",这个快捷指向了我们安装在node_modules中的vite包里的一个脚本文件。

npm帮我们处理了不同操作系统的差异,让我们可以用同样的命令在各个平台上工作。

相关推荐
吃饺子不吃馅15 小时前
[开源] 从零到一打造在线 PPT 编辑器:React + Zustand + Zundo
前端·svg·图形学
小马哥编程16 小时前
【软考架构】案例分析-Web应用设计(应用服务器概念)
前端·架构
鱼与宇16 小时前
苍穹外卖-VUE
前端·javascript·vue.js
啃火龙果的兔子16 小时前
前端直接渲染Markdown
前端
z-robot16 小时前
Nginx 配置代理
前端
用户479492835691516 小时前
Safari 中文输入法的诡异 Bug:为什么输入 @ 会变成 @@? ## 开头 做 @ 提及功能的时候,测试同学用 Safari 测出了个奇怪的问题
前端·javascript·浏览器
没有故事、有酒16 小时前
Ajax介绍
前端·ajax·okhttp
朝新_16 小时前
【SpringMVC】详解用户登录前后端交互流程:AJAX 异步通信与 Session 机制实战
前端·笔记·spring·ajax·交互·javaee
裴嘉靖16 小时前
Vue 生成 PDF 完整教程
前端·vue.js·pdf
毕设小屋vx ylw28242616 小时前
Java开发、Java Web应用、前端技术及Vue项目
java·前端·vue.js