一、必備外掛
1. babel:es6語法支援,需要babel-perset-es2015(轉換成es5執行)、babel、babel-core(程式執行)
2. commander:自定義命令外掛,提供引數的傳遞等
3. liftoff:實現對命令視窗的輸入監聽,以及命令格式化規格。
4. minimist:讀取命令列引數外掛
以上外掛都可以通過npm直接安裝。
二、示例程式碼分析:
2.1. cli.js
var liftOff = require("liftoff");
import app from "./app";
var argv = require("minimist")(process.argv.slice(2));
var cli =new liftOff({
name: "sam",
processTitle: 'samLong',
moduleName: "sam",
extensions:{
'.js':null
}
});
cli.launch({
cwd: argv.r || argv.root,
configPath: argv.f || argv.file
},function(env){
console.log("命令名稱:" + argv["_"]);
console.log( "執行路徑:" + env.cwd);
var commander = require('commander');
var _app = new app();
_app.register(commander);
});
1. liftOff類:通過匯入liftOff第三方外掛實現對命令列引數進行解析,且通過liftOff的例項方法launch進行捕獲
2. require("minimist")(process.argv.slice(2)):將命令列引數轉換為物件
3. ./app:匯入命令執行類
2.2. app.js
class App { register(commander) { commander .option('-d --date', "顯示時間") .parse(process.argv); if (commander.date) { console.log('date命令被執行'); } } }; export default App;
通過commander實現的一個簡單的命令執行類。
2.3. index.js
require("babel-core/register"); //匯入babel-core,用於在程式碼中轉換我es6 require("./src/app"); require('./src/cli');
2.4. 執行效果:
三、GIt地址
git@code.csdn.net:cqhaibin/commandertest.git