zoukankan      html  css  js  c++  java
  • 如何使用Node.js编写命令工具——以vue-cli为例

    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('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)
    

      

     该命令采用commander.js来实现。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。

    vue-init子命令的实现

    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命令的实现原理,敬请期待!

  • 相关阅读:
    Codeforces Round #631 (Div. 1) B. Dreamoon Likes Sequences 题解(思维+求贡献)
    牛客练习赛66 C公因子 题解(区间gcd)
    evincevim控喜欢的pdf阅读器
    水手郑智化
    使用diskpart管理自己的分区
    Hacker's Browser
    How Browser Works
    解决vim ctags R失败的问题
    ubuntu更改登录对话框
    使用bcdedit删除多个Windows系统
  • 原文地址:https://www.cnblogs.com/wmhuang/p/7092658.html
Copyright © 2011-2022 走看看