ホームページ >ウェブフロントエンド >jsチュートリアル >mycliコマンドラインツールのノード実践開発

mycliコマンドラインツールのノード実践開発

青灯夜游
青灯夜游転載
2022-06-06 18:58:542589ブラウズ

この記事では、node の実戦を段階的に理解し、ノードに基づいた mycli コマンド ライン ツール/スキャフォールディングの作成方法について説明します。

mycliコマンドラインツールのノード実践開発

初期化

まず、コンピューター上に node.js 環境があることを確認します。

コマンド ラインで次のコードを実行して、package.json ファイル

npm init -y

を初期化します。このとき、コマンドを実行すると必ずエラーが報告されます。行は mycli を実行します。

mycliコマンドラインツールのノード実践開発

カスタム コマンドの構成

package.json Add bin フィールド、関連付けられた myclicommand

  • 各コマンドは、実行可能ファイル
  "bin": {
    "mycli": "./test.js"
  },
  • New/test に対応します。 jsFile
console.log("mycli命令执行成功");
  • には install インストール コマンドが必要ですが、プロジェクトはまだ npm に公開されていないため、npm リンク##を使用してください#Command、mycli コマンドをグローバル ワールドに関連付けます。
この時点で、コマンド ライン

mycli を実行しても、それ以上エラーは報告されません。

mycliコマンドラインツールのノード実践開発

#スクリプト構成test.js ファイル:

console.log("mycli命令执行成功");

次に # を実行します。 ##mycli

、エラー ポップアップ ウィンドウが表示されます

これは、mycliコマンドラインツールのノード実践開発mycli

コマンドを実行すると、Let と同等であるためです。コンピュータはこのファイルを実行しますが、コンピュータ システム

は js ファイル を直接実行できません。これには、スクリプト コードの最初の行に構成を追加して、node.js## を指定する必要があります。 #このjsスクリプトファイルを実行するプログラム。

#!/usr/bin/env node
実行環境を変更したため、以前にリンクしたファイルを削除する必要があります。ファイルの場所は C:\Program Files\nodejs\node_modules である可能性があります。

mycli# を見つけてください。 ## を削除してから、

npm link を再度実行します。 次に、コンソールで mycli を実行すると、コンソールが正しく印刷されることがわかります。

関連ツールキットの使用

Chalk コマンド ライン出力のカラフルなフォント

  • Oraロードの効果は、進行状況ライブラリ
  • commander デザイン コマンド
  • inquirer インタラクティブ機能 (質問するなど) と似ています。
  • Chalk

インストール

npm install chalk@4.1.2 -S

    test.js# を使用する
  • ##
    const chalk = require("chalk");
    
    // chalk
    // const hello = chalk.red("hello");
    // const hello = chalk.blue.bgRed("hello");
    // const hello = chalk.blue.bgYellow("hello");
    const hello = chalk.rgb(200, 200, 200).bgRgb(0, 200, 3)("hello");
    console.log(hello);
  • ##Ora

mycliコマンドラインツールのノード実践開発

インストール

npm install ora@4.0.3 -S
test.js を使用する

    const ora = require("ora");
    
    // ora
    const spinner = ora({
      text: "安装中..."
    });
    spinner.start();
    setTimeout(() => {
      // spinner.stop();
      spinner.succeed("安装成功");
      // console.log("安装成功");
    }, 2000)
  • 一般的に使用される API
  • start
  • 読み込み開始
  • stop
      読み込みを停止します
    • succeed
    • 成功したスタイルで読み込みを終了します
  • #コマンダー

mycliコマンドラインツールのノード実践開発

開発で一般的に使用されるコマンド (

vue -V git --version vue Create

など)コマンドを実装したい場合は、

commander ライブラリを使用する必要があります。 使用したコマンドの後ろにある -V --help などはコマンドのパラメータとして理解できるので、これらのパラメータを取得して判断する必要があります。さまざまなイベントを処理するには、さまざまなパラメータが使用されます。

node 環境では、process.argv を通じてこのパラメーターを取得できます。 commander

ライブラリは、ユーザーの入力によって伝えられる命令を判断することなく、いくつかのメソッドをカプセル化するのに役立ちます。

インストール

npm install commander@8.2.0 -S
使用

    const commander = require("commander");
    // ...
    commander.parse(process.argv); // 放在后面
  • インストールが完了すると、
  • commander
が自動的に起動されます。
    --help
  • などのいくつかのコマンドを以下でテストしてみましょう:
  • mycli --help

はバージョン番号を設定するメソッドを提供します

commander.version("1.0.0");
Execute mycli -V

コンソールに
    1.0.0
  • のバージョン番号が出力されることがわかります。

カスタム コマンド メソッドcommander.option(コマンド名、説明、コールバック関数)

の一部上で書かれた関数は

--init

コマンドに設定されています:

commander.option("--init", "this is init", () => {
  // chalk
  // const hello = chalk.red("hello");
  // const hello = chalk.blue.bgRed("hello");
  // const hello = chalk.blue.bgYellow("hello");
  const hello = chalk.rgb(200, 200, 200).bgRgb(0, 200, 3)("hello");
  console.log(hello);

  // ora
  const spinner = ora({
    text: "安装中..."
  });
  spinner.start();
  setTimeout(() => {
    // spinner.stop();
    spinner.succeed("安装成功");
    // console.log("安装成功");
  }, 1000)
})

ここで
    mycli --init
  • テストを実行します:
  • 在指令中传递参数的写法
commander.option("--number <num>", "log a number", (num) => {
  console.log(num);
})

表示必传的参数,[参数名]表示非必传的参数。控制台输入mycli --number 100回车,可以看到会输出100

自定义命令方法

commander.command("create <projectName>").action((projectName)=>{
  console.log(projectName);
})

执行 mycli create xx 回车,控制台可以看到 输出了xx

查看帮助

执行 mycli --help,可以看到我们刚才配置的指令和命令都出现在了帮助列表里。

mycliコマンドラインツールのノード実践開発

inquirer

  • 安装
npm install inquirer -S
  • prompt提问的方法
  inquirer.prompt([
    {
      type: "input",
      name: "username",
      message: "请输入用户名:"
    }
  ]).then((answer)=>{

  })

type表示问题的类型,取值可能是:input, number, password, editor等。

answer{username: 输入的值}

  • type是输入类型的 input
const inquirer = require("inquirer");

commander.command("add user").action(() => {
  inquirer.prompt([
    {
      type: "input",
      name: "username",
      message: "请输入用户名:"
    }
  ]).then((answer) => {
    console.log(answer);
  })
})
  • type是判断类型的 confirm
commander.command("testcon").action(() => {
  inquirer.prompt([
    {
      type: "confirm",
      name: "age",
      message: "是否大于18岁?"
    }
  ]).then((answer) => {
    console.log(answer);
  })
})

输入yn来进行判断。

mycliコマンドラインツールのノード実践開発

  • type是单选类型 list
commander.command("testlist").action(() => {
  inquirer.prompt([
    {
      type: "list",
      name: "lib",
      message: "选择用到的框架:",
      choices: [
        "vue2",
        "vue3",
        "react",
        "svelte",
      ]
    }
  ]).then((answer) => {
    console.log(answer);
  })
})

执行 mycli testlist 命令:

mycliコマンドラインツールのノード実践開発

下载模板

  • download-git-repo是一个拉取代码的工具。

  • 安装

npm install download-git-repo@3.0.2 -S
  • 使用
const downgit = require("download-git-repo");

downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) {
    console.log(err)
})

downgit方法里面的第一个参数理解为在github上面下载kongcodes用户的vue3-vant项目模板。第二个参数downUrl 为要将模板下载到什么目录下。第三个参数clone 是否要用git clone下载。第四个参数 为下载完成执行的一些事情。

  • 结合command方法使用
commander.command("create <projectName>").action((projectName) => {
  const spinner = ora({
    text: "正在下载https://github.com/kongcodes/vue3-vant..."
  });
  spinner.start();
  fs.mkdirSync(`./${projectName}`);
  const downUrl = `${process.cwd()}\\${projectName}`;
  downgit("github:kongcodes/vue3-vant", downUrl, { clone: false }, function (err) {
    if (err) throw err;
    spinner.stop();
    console.log(chalk.green("downgit success"));
  })
})

执行 mycli create pro 回车,会在当前目录下创建pro目录,下载vue3-vant模板到这个目录里。

代码地址

https://github.com/kongcodes/mycli

更多node相关知识,请访问:nodejs 教程

以上がmycliコマンドラインツールのノード実践開発の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はjuejin.cnで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。