详解如何使用Node.js编写命令工具——以vue-cli为例
全局安装之后,提供了vue命令和vue init、vue list、vue build三个子命令,通过命令可以搭建基于vue.js的脚手架项目。本文简单介绍一下这些命令是如何实现的。
vue-cli的项目目录
如下图,由之前介绍,npm安装过程中,可以利用package.json中bin字段的配置,将bin目录下的命令文件软连到全局命令。也就是说在/usr/local/bin下生成了四个软连命令vue、vue-build、vue-list、vue-init。
vue命令的源码
#!/usr/bin/env node require('mander') .version(require('../package').version) .usage('<mand> [options]') .mand('init', 'generate a new project from a template') .mand('list', 'list available official templates') .mand('build', 'prototype a new project') .parse(process.argv)
该命令采用来实现。mander的主要方法
(1)parse用于解析process.argv,将process.argv.slice(2)赋值给program.args;
(2)mand创建子命令,子命令的使用方法是mand <submand> [options],实际调用的命令是mand-submand,如使用命令行执行vue list,其实是在执行vue-list全局命令;
(3)options主要设置命令的参数,提供参数对应的说明文档,默认提供的option是--help。
vue-init子命令的实现
vue-init的主要功能是拉取指定git目录下的项目模板文件(官方或自制)到指定目录下,用法如下
$ vue init <template-name> <project-name>
这里仍需要解析process.argv,所以在vue-init中又引入了mander.js,生成了一个program
program .usage('<template-name> [project-name]') .option('--offline', 'use cached template') / Help. / function help () { program.parse(process.argv) if (program.args.length < 1) return program.help() } help()
接下来就是要实现拉取模板文件,经处理后,放置到产出目录下,具体如何实现的,接下来会有专门的文章介绍vue-cli命令的实现原理,敬请期待!
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程