执行 npm run serve 时发生了什么?

2024-04-09 18:52
文章标签 npm 执行 发生 run serve

本文主要是介绍执行 npm run serve 时发生了什么?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在前端开发中,npm run serve 是一个常见的命令,尤其是在使用 Vue CLI 构建项目时。但是为什么直接运行 vue-cli-service serve 会报错,但使用 npm run serve 却可以成功启动项目呢?

npm scripts 的基本原理

先回顾一下 npm 命令的基本原理。在 package.json 文件中的 "scripts" 字段允许我们定义一组自定义的命令。例如:

"scripts": {"start": "node index.js","serve": "vue-cli-service serve",// 其他命令...
}

这里 "serve" 就是我们需要执行的命令,其对应的值是执行 vue-cli-service serve。运行 npm run serve 实际上是在执行 vue-cli-service serve 命令。

为什么直接运行 vue-cli-service serve 会报错?

直接运行 vue-cli-service serve 会导致错误的主要原因在于 vue-cli-service 不是一个全局可执行命令,而是作为项目依赖安装在项目的 node_modules 中。

运行 vue-cli-service serve 时,操作系统并不知道去哪里找这个命令。而通过 npm run serve,我们在 package.json 的 "scripts" 中定义了 serve 对应的命令是 vue-cli-service serve,这时 npm 根据查找规则就能够正确找到并执行这个命令。

npm run serve 查找规则

npm run serve 的执行过程涉及以下步骤:

  • 查找命令npm 首先在当前项目目录的 node_modules/.bin 目录下查找是否存在 vue-cli-service 可执行文件。

  • 查找全局安装:如果在项目的 node_modules/.bin 中没有找到 vue-cli-servicenpm 会继续在全局 node_modules/.bin 目录下查找 <script> 对应的可执行文件。

  • 执行命令:找到 vue-cli-service 后,npm 将执行该命令

这个查找过程确保了我们可以在项目内部或全局的依赖中找到并执行指定的命令,相当于执行了 ./node_modules/.bin/vue-cli-service serve

npm scripts 的命令注入机制

在执行 npm run serve 时,npm 实际上会将项目的 node_modules/.bin 目录添加到系统的 PATH 中。这个目录包含了大部分通过 npm install 安装的可执行文件,其中也包括了 vue-cli-service

这样一来,系统就能够在全局范围内找到 vue-cli-service 命令,不用在命令行中指定完整的路径。

全局安装

当某个包被全局安装时,其可执行文件也会被放置在全局 node_modules/.bin 目录中。如果全局的 node_modules/.bin 目录也被加入系统的 PATH 中,那么在全局范围内就可以运行该可执行文件。

这种机制使得一些工具和命令行程序能够在任何地方都能被直接调用,而无需指定完整路径。

vue-cli-service 来自哪里

vue-cli-service 命令是 Vue CLI 提供的可执行文件,在项目初始化时会自动创建一个 .bin 目录,其中包含了一些项目本地的可执行文件。

当我们通过 Vue CLI 创建一个新的 Vue.js 项目时,它会在项目的 node_modules/.bin 目录下创建一个名为 vue-cli-service(或者是 vue-cli-service.cmd,这取决于你使用的是 Windows 还是其他系统)的可执行文件。

这个可执行文件实际上是指向项目安装的 @vue/cli-service 包中的 bin/vue-cli-service.js 文件的一个软链接,这个文件是 Vue CLI 提供的命令行工具的入口文件。

当我们在 package.json 文件的 "scripts" 字段中使用 vue-cli-service 命令时,实际上是在调用这个项目本地的可执行文件,而不是全局安装的 Vue CLI。

好处在于每个 Vue.js 项目都可以有自己的 vue-cli-service 可执行文件,这样可以确保在不同的项目中使用不同版本的 Vue CLI 而不会相互影响。

npm scripts 进阶用法

除了简单的命令,npm scripts 还支持并行执行多个命令,以及通过插件实现更高级的功能。以下是一个使用 npm-run-all 插件实现并行执行命令的例子:

"scripts": {"start": "npm-run-all --parallel task1 task2","task1": "command1","task2": "command2"
}

在这个例子中,npm run start 将同时执行 task1 和 task2

这篇关于执行 npm run serve 时发生了什么?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/888950

相关文章

Kotlin 作用域函数apply、let、run、with、also使用指南

《Kotlin作用域函数apply、let、run、with、also使用指南》在Kotlin开发中,作用域函数(ScopeFunctions)是一组能让代码更简洁、更函数式的高阶函数,本文将... 目录一、引言:为什么需要作用域函数?二、作用域函China编程数详解1. apply:对象配置的 “流式构建器”最

Spring定时任务只执行一次的原因分析与解决方案

《Spring定时任务只执行一次的原因分析与解决方案》在使用Spring的@Scheduled定时任务时,你是否遇到过任务只执行一次,后续不再触发的情况?这种情况可能由多种原因导致,如未启用调度、线程... 目录1. 问题背景2. Spring定时任务的基本用法3. 为什么定时任务只执行一次?3.1 未启用

grom设置全局日志实现执行并打印sql语句

《grom设置全局日志实现执行并打印sql语句》本文主要介绍了grom设置全局日志实现执行并打印sql语句,包括设置日志级别、实现自定义Logger接口以及如何使用GORM的默认logger,通过这些... 目录gorm中的自定义日志gorm中日志的其他操作日志级别Debug自定义 Loggergorm中的

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

在MySQL执行UPDATE语句时遇到的错误1175的解决方案

《在MySQL执行UPDATE语句时遇到的错误1175的解决方案》MySQL安全更新模式(SafeUpdateMode)限制了UPDATE和DELETE操作,要求使用WHERE子句时必须基于主键或索引... mysql 中遇到的 Error Code: 1175 是由于启用了 安全更新模式(Safe Upd

Spring Boot 整合 ShedLock 处理定时任务重复执行的问题小结

《SpringBoot整合ShedLock处理定时任务重复执行的问题小结》ShedLock是解决分布式系统中定时任务重复执行问题的Java库,通过在数据库中加锁,确保只有一个节点在指定时间执行... 目录前言什么是 ShedLock?ShedLock 的工作原理:定时任务重复执行China编程的问题使用 Shed

详解如何在React中执行条件渲染

《详解如何在React中执行条件渲染》在现代Web开发中,React作为一种流行的JavaScript库,为开发者提供了一种高效构建用户界面的方式,条件渲染是React中的一个关键概念,本文将深入探讨... 目录引言什么是条件渲染?基础示例使用逻辑与运算符(&&)使用条件语句列表中的条件渲染总结引言在现代

python subprocess.run中的具体使用

《pythonsubprocess.run中的具体使用》subprocess.run是Python3.5及以上版本中用于运行子进程的函数,它提供了更简单和更强大的方式来创建和管理子进程,本文就来详细... 目录一、详解1.1、基本用法1.2、参数详解1.3、返回值1.4、示例1.5、总结二、subproce

如何使用 Bash 脚本中的time命令来统计命令执行时间(中英双语)

《如何使用Bash脚本中的time命令来统计命令执行时间(中英双语)》本文介绍了如何在Bash脚本中使用`time`命令来测量命令执行时间,包括`real`、`user`和`sys`三个时间指标,... 使用 Bash 脚本中的 time 命令来统计命令执行时间在日常的开发和运维过程中,性能监控和优化是不

C#如何优雅地取消进程的执行之Cancellation详解

《C#如何优雅地取消进程的执行之Cancellation详解》本文介绍了.NET框架中的取消协作模型,包括CancellationToken的使用、取消请求的发送和接收、以及如何处理取消事件... 目录概述与取消线程相关的类型代码举例操作取消vs对象取消监听并响应取消请求轮询监听通过回调注册进行监听使用Wa