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

  • 相关阅读:
    Homebrew简介及安装
    MongoDB MapReduce学习笔记
    mongodb_修改器($inc/$set/$unset/$push/$pop/upsert......)
    【资源共享】《Rockchip 量产烧录 指南 V1.0》
    【资源共享】《DDR常见问题简单排查》
    【技术案例】Firefly-RK3399多路视频编解码
    【资源共享】《Rockchip 以太网 开发指南 V2.3.1》
    【资源共享】Rockchip Audio 开发指南
    关于在RK3288上安装Opencv的方法
    debian stretch + kernel 4.4 固件发布(支持硬件加速),可安装kodi
  • 原文地址:https://www.cnblogs.com/wmhuang/p/7092658.html
Copyright © 2020-2023  润新知