一、必備插件 1. babel:es6語法支持,需要babel-perset-es2015(轉換成es5執行)、babel、babel-core(程式執行) 2. commander:自定義命令插件,提供參數的傳遞等 3. liftoff:實現對命令視窗的輸入監聽,以及命令格式化規格。 4. min... ...
一、必備插件
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地址
[email protected]:cqhaibin/commandertest.git