上一篇文章,已经大致了解脚手架是什么以及脚手架是如何工作的。接下来,稍微深入一下脚手架的工作过程(以vue-cli为例)。首先抛出3个问题:

  1.明明全局安装的是@vue/cli,最后执行的命令却是vue?

  2.全局安装@vue/cli时发生了什么?

  3.执行vue命令时发生了什么,为什么vue指向某个文件,我们却可以直接通过vue命令执行它?

  弄清楚这3个问题,基本上对脚手架的原理已经有个大体的认识,文章最后会详解自定义npm命令哦~

  首先,第一个问题为什么安装的是@vue/cli,执行的命令是vue,先找到npm文件夹:

  

  这是vue命令的执行文件,打开会发现有这样一行代码:

   1 endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\node_modules\vue-cli\bin\vue" %*

  这行代码的作用是,将当前命令指向\node_modules\vue-cli\bin\vue,所以即使我们用的命令是vue,最终还是指向@vue/cli内部的文件。

  第二个问题,全局安装@vue/cli时发生了什么:

  1.下载node_modules

  2.在package.json里面配置bin的软链接:

  

  第三个问题,vue命令最终会指向vue-cli内的某个文件,为什么可以执行它:

  前面我们已经知道,vue命令执行的时候,会先找到vue文件(AppData\Roaming\npm\vue.cmd)并执行,执行这个vue文件的时候,会发现这是一个软链接,实际指向的是:\node_modules\vue-cli\bin\vue 该路径的vue文件,最后才会执行这个文件。那么问题来了,vue命令指向的这个文件,是如何执行的?前端的同学们都知道,node环境下执行js文件,需要加一个node命令前缀,才可以执行该js文件。那这个地方的文件,是如何执行的呢?我们找到vue-cli\bin\vue文件:

  打开会是下面这几行代码:

 1 #!/usr/bin/env node
2
3 const program = require('commander')
4
5 program
6 .version(require('../package').version)
7 .usage('<command> [options]')
8 .command('init', 'generate a new project from a template')
9 .command('list', 'list available official templates')
10 .command('build', 'prototype a new project')
11 .command('create', '(for v3 warning only)')
12
13 program.parse(process.argv)

  没错,主要就是第一行代码:

1 #!/usr/bin/env node

  这行代码的作用,它会在我们的环境变量中找到node命令,并用node命令执行该文件!致此,这三个问题都已经有了答案,现在再来看一下:vue create vue-test这条命令的执行过程:

  1.在终端输入:vue create vue-test

  2.终端解析出vue命令

  3.终端在环境变量中找到vue命令

  4.终端根据vue命令链接到实际文件vue

  5.终端利用node执行vue文件

  6.vue解析command/options

  7.vue执行command

  8.执行完毕,退出

  现在是不是对脚手架的工作原理理解更深刻一点了呢,其中的command将会在以后开发脚手架的时候会单独拿出来讨论。

  下面介绍自定义npm指令以及其软链接到其它文件:

  首先在npm文件夹下新建一个wang.cmd:

 1 @ECHO off
2 GOTO start
3 :find_dp0
4 SET dp0=%~dp0
5 EXIT /b
6 :start
7 SETLOCAL
8 CALL :find_dp0
9
10 IF EXIST "%dp0%\node.exe" (
11 SET "_prog=%dp0%\node.exe"
12 ) ELSE (
13 SET "_prog=node"
14 SET PATHEXT=%PATHEXT:;.JS;=;%
15 )
16
17 endLocal & goto #_undefined_# 2>NUL || title %COMSPEC% & "%_prog%" "%dp0%\node_modules\vue-cli\bin\wang" %*

  最终指向到vue-cli\bin\wang:

1 #!/usr/bin/env node
2
3 console.log('wang')

  执行wang:

最后:脚踏实地行,海阔天空飞!

浅析vue-cli脚手架命令的执行过程的更多相关文章

  1. 13. Vue CLI脚手架

    一. Vue CLI 介绍 1. 什么是Vue CLI? Vue CLI 是一个基于 Vue.js 进行快速开发的完整系统.Vue CLI 致力于将 Vue 生态中的工具基础标准化.它确保了各种构建工 ...

  2. 深入Redis命令的执行过程

    深入Redis命令的执行过程 Redis 服务器: Redis 服务器实现与多个客户端的连接,并处理这些客户端发送过来的请求,同时保存客户端执行命令所产生的数据到数据库中.Redis 服务器依靠资源管 ...

  3. 使用Vue CLI脚手架搭建vue项目

    本次是使用@vue/cli 3.11.0版本搭建的vue项目 1. 首先确保自己的电脑上的Node.js的版本是8.9版本或者以上 2. 全局安装vue/cli npm install @vue/cl ...

  4. Ping 命令的执行过程和应用协议

    1. ICMP是“Internet Control Message Ptotocol”的缩写.它是TCP/IP协议族的一个子协议,用于在IP主机.路由器之间传递控制消息. 控制消息是指网络通不通.主机 ...

  5. vue cli脚手架使用

    1.安装nodejs,npm https://www.cnblogs.com/xidianzxm/p/12036880.html 2.安装vue cli sudo npm install -g @vu ...

  6. 关于ansible命令的执行过程

    首先说明一下.每一个模块.都是有相应的.py文件的,可以通过rpm -ql ansible看到 要观察模块执行过程,可以在ansible命令执行时加上-v或-vvv,或者-vvvv看得更加详细 ans ...

  7. sqlplus文件查看自带oracle命令的执行过程

    问题描述:看到一篇文章 在$ORACLE_HOME/bin/sqlplus中可以查看到数据库命令的查询语句.可以直接编辑sqlplus文件,查到到我们平时标准系统命令的原脚本,但是自己进行编辑查看却是 ...

  8. vue.cli脚手架初次使用图文教程

    vue-cli作用 vue-cli作为vue的脚手架,可以帮助我们在实际开发中自动生成vue.js的模板工程. vue-cli使用 !!前提:需要vue和webpack 安装全局vue-cli npm ...

  9. node.js和vue cli脚手架下载安装配置方法

    一.node.js安装以及环境配置 1.下载vue.js 下载地址: https://nodejs.org/en/ 2.安装node.js 下载完成后,双击安装包开始安装.安装地址最好换成自己指定的地 ...

随机推荐

  1. GVS案例分享|乘新时代姑苏舫号,体验匠心智能控制

    水,是苏州的灵魂,串起苏州的古与今.动与静.金鸡湖景区位于苏州工业园区,总面积11.5平方公里,其中水域面积7.4平方公里. 新时代姑苏舫号,是金鸡湖景区极具苏式特征且规格超高的游览船型.船体分为上下 ...

  2. TcaplusDB祝大家端午安康!

    "五月五,端午到,赛龙舟,真热闹.吃粽子,带香包,蚊虫不来身边闹."这首脍炙人口.描绘着端午节风俗的儿歌,想必大家都听过. 每年的农历五月初五,是我国四大传统节日(春节.清明节.端 ...

  3. JVM集合之开篇点题

    大家在平时的开发过程中是否遇到过StackOverflowError.OutOfMemoryError等类似的内存溢出错误呢?大家又是怎么解决这个问题的?再来,大家在面试过程中有没有被面试官提问过jv ...

  4. docker0-常用命令-持续更新

    问君哪得清如许,为有源头活水来 1,帮助命令 docker version docker info docker 命令 --help 2,仓库\镜像 docker images 查看所有本地镜像 do ...

  5. Java安全之反序列化回显研究

    Java安全之反序列化回显研究 0x00 前言 续上文反序列化回显与内存马,继续来看看反序列化回显的方式.上篇文中其实是利用中间件中存储的Request 和Response对象来进行回显.但并不止这么 ...

  6. 浏览器中js怎么将图片下载而不是直接打开

    网上找了好多方法都是不能用的,经过试验在Chrome中都是直接打开. 经过自己的摸索,找到了一套能用的解决方案 var database = "data:image/jpg;base64,& ...

  7. beego搭建api服务

    beego介绍 beego是一个Golang实现的开源Go应用开发框架,他可以用来快速开发 API.Web 及后端服务等各种应用,是一个 RESTful的框架,主要设计灵感来源于tornado.sin ...

  8. Unity中各种查找物体的方法

    本文转自博主:Teng的世界 https://blog.csdn.net/teng_ontheway/article/details/47188141 GameObject.Find().Transf ...

  9. 通过busybox制作根文件系统详细过程

    我在之前的uboot通过NFS挂载ubuntu根文件系统中也有实现过根文件系统的制作,那只是在ubuntu官网已经做好的根文件基础上安装一些自己所需的软解而已.而使用busybox制作根文件系统可以自 ...

  10. 6.11、制作windos虚拟机

    1.下载kvm支持windows系统的驱动程序: cd /tmp/ wget https://fedorapeople.org/groups/virt/virtio-win/direct-downlo ...