源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

详解如何使用Node.js编写命令工具——以vue-cli为例

  • 时间:2021-12-17 02:59 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:详解如何使用Node.js编写命令工具——以vue-cli为例
[url=https://github.com/vuejs/vue-cli]vue-cli[/url]全局安装之后,提供了vue命令和vue init、vue list、vue build三个子命令,通过命令可以搭建基于vue.js的脚手架项目。本文简单介绍一下这些命令是如何实现的。 [b]vue-cli的项目目录[/b] 如下图,由之前[url=http://www.1sucai.cn/article/116846.htm]文章[/url]介绍,npm安装过程中,可以利用package.json中bin字段的配置,将bin目录下的命令文件软连到全局命令。也就是说在/usr/local/bin下生成了四个软连命令:vue、vue-build、vue-list、vue-init。 [img]http://files.jb51.net/file_images/article/201706/2017062909431221.png[/img] [img]http://files.jb51.net/file_images/article/201706/2017062909431222.png[/img]   [b]vue命令的源码[/b]
#!/usr/bin/env node

 

require('commander')

 .version(require('../package').version)

 .usage('<command> [options]')

 .command('init', 'generate a new project from a template')

 .command('list', 'list available official templates')

 .command('build', 'prototype a new project')

 .parse(process.argv) 

 该命令采用[url=https://github.com/tj/commander.js]commander.js[/url]来实现。commander的主要方法: (1)parse:用于解析process.argv,将process.argv.slice(2)赋值给program.args; (2)command:创建子命令,子命令的使用方法是command <subcommand> [options],实际调用的命令是command-subcommand,如使用命令行执行vue list,其实是在执行vue-list全局命令; (3)options:主要设置命令的参数,同时提供参数对应的说明文档,默认提供的option是--help。 [b]vue-init子命令的实现[/b] vue-init的主要功能是拉取指定git目录下的项目模板文件(官方或自制)到指定目录下,用法如下
$ vue init <template-name> <project-name> 
这里仍需要解析process.argv,所以在vue-init中又引入了commander.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命令的实现原理,敬请期待! 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程素材网。
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部