• 且看这个Node全栈框架,实现了个Cli终端引擎,可无限扩充命令集


    背景介绍

    一般而言,大多数框架都会提供Cli终端工具,用于通过命令行执行一些工具类脚本

    CabloyJS提供的Cli终端工具却与众不同。更确切的说,CabloyJS提供的是Cli终端引擎,由一套Cli终端运行机制+众多命令集组成。CabloyJS是一个基于模块化体系的全栈框架,因此,命令集也由具体的模块提供。因此,我们可以通过安装各种模块来动态添加可以运行的命令集,从而让CabloyJS的Cli终端变得无比强大、功能也无比丰富

    特点

    1. 可无限扩充:由于是通过安装模块来提供命令集,因此可以无限扩充

    2. 同时支持开发环境生产环境:当我们在命令行输入指令后,系统会自动调用后端服务的API接口,执行具体的脚本逻辑。而后端服务既可以是在本地运行的开发服务,也可以是在远程运行的生成环境

    3. 简化系统管理运维工作:正是由于Cli终端可以用于生产环境,所以许多后台管理工作都可以通过API接口暴露出来,从而可以直接通过命令行进行驱动

    4. 完善的权限控制:后端服务暴露的所有API接口都使用资源授权机制进行控制,Cli终端通过开放认证Token进行受控访问

    如何使用

    Cli终端的使用规范如下:

    $ npm run cli [command] [args] -- [options]
    

    - command

    1. 命名规范:由于command由业务模块提供,为了进一步规范管理,在业务模块内部还将提供的commands进行分组。因此,command命名规范如下:
    moduleName:groupName:commandName
    

    比如,模块a-clibooster提供了一个分组create,分组create提供了一个module 命令,那么,完整的command命名就是:a-clibooster:create:module

    1. 特殊约定:为了简化command的输入,特别做了如下约定:

      1. 如果模块名称是a-clibooster,则可以不输入

      2. 如果分组名称是default,则可以不输入

    举例如下:

    全称 简称
    a-clibooster:default:list ::list
    a-clibooster:create:module :create:module
    test-party:default:demo test-party::demo

    - args

    命令后是否可以跟随参数,跟随多少参数,由具体的命令决定,例如:

    # 安装模块test-flow和test-note
    $ npm run cli :store:sync test-flow test-note
    

    - options

    命令后是否可以跟随选项,跟随多少选项,也由具体的命令决定,例如:

    # 向套件test-suite1添加模块test-module1
    $ npm run cli :create:module test-module1 -- --suite=test-suite1
    

    - help

    如果我们不知道如何使用某个命令,可以直接打印出帮助信息,例如

    $ npm run cli :create:module -- --help
    

    - version

    还可查询某个命令的版本号,例如:

    $ npm run cli :create:module -- --version
    

    - 列出命令

    如果要查询当前系统一共支持多少命令,可以按如下操作:

    # 列出所有命令
    $ npm run cli ::list
    # 列出模块test-party提供的命令
    $ npm run cli ::list  -- --module=test-party
    # 列出模块a-clibooster内create分组提供的命令
    $ npm run cli ::list  -- --module=a-clibooster --group=create
    

    内置命令

    CabloyJS通过模块a-clibooster内置了大量常用的命令,具体如下:

    命令 描述
    ::list 列出所有命令
    :token:add 添加开放认证Token
    :token:delete 删除开放认证Token
    :token:list 列出所有开放认证Token
    :tools:babel 编译JS文件
    :tools:icons 处理图标模块
    :create:suite 新建套件
    :create:module 新建模块
    :create:atom 新建原子类型
    :create:controller 新建控制器(包括Route、Controller、Service一套文件)
    :store:sync 安装来自Cabloy商店的套件/模块
    :store:publish 将本地开发的套件/模块发布到Cabloy商店

    简写命令

    CabloyJS还提供了更多简写命令,可以亲自体验一番,一定会显著提升开发效率

    $ npm run cli
    $ npm run cli :
    $ npm run cli ::
    $ npm run cli :default:
    $ npm run cli :create:
    $ npm run cli test-party:
    $ npm run cli test-party::
    $ npm run cli test-party:default:
    

    如何创建Cli命令

    如果我们想创建自己的Cli命令,也非常简便,参见文档:如何创建Cli命令

    相关链接

  • 相关阅读:
    C++学习记录1
    普中51-独立按键实验
    第二课 Flink 安装部署、环境配置及运行应用程序(1)
    计算机毕业设计(附源码)python圆梦酒店管理系统
    第18章 SpringCloud生态(二)
    计算机网络——以太网的信道利用率
    ul滚动卡顿解决办法分享
    @Autowired注解在spring中的用法
    小趴菜实战Mac上安装Anaconda
    计算机视觉:使用opencv实现银行卡号识别
  • 原文地址:https://www.cnblogs.com/zhennann/p/16356492.html