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

  • 相关阅读:
    Zabbix触发器支持的函数说明
    Zabbix Trigger表达式实例
    Nginx 504 Gateway Time-out问题解决
    题外话:我想立刻辞职,然后闭关学习编程语言,我给自己3个月时间学习C语言!这样行的通吗
    Vim快捷键分类
    [转]运维工作解释
    Cobbler的Web管理和维护
    使用 Cobbler 自动化和管理系统安装
    NTP时间服务器
    自动化部署必备技能—搭建YUM仓库
  • 原文地址:https://www.cnblogs.com/wmhuang/p/7092658.html
Copyright © 2020-2023  润新知