Rumah >hujung hadapan web >tutorial js >Pembangunan praktikal nod alat baris arahan mycli

Pembangunan praktikal nod alat baris arahan mycli

青灯夜游
青灯夜游ke hadapan
2022-06-06 18:58:542591semak imbas

Artikel ini akan membawa anda langkah demi langkah untuk memahami amalan nod, dan bercakap tentang cara membuat alat/perancah baris arahan mycli berdasarkan nod.

Pembangunan praktikal nod alat baris arahan mycli

Inisialisasi

Mula-mula pastikan terdapat persekitaran node.js pada komputer anda

Baris arahan melaksanakan kod berikut untuk memulakan fail package.json

npm init -y

Pada masa ini, pelaksanaan baris arahan mycli pasti akan melaporkan ralat.

Pembangunan praktikal nod alat baris arahan mycli

Konfigurasikan perintah tersuai

package.json Tambah medan bin, kaitkan mycli Perintah

  • Setiap arahan sepadan dengan fail boleh laku
  "bin": {
    "mycli": "./test.js"
  },
  • Buat fail /test.js baharu
console.log("mycli命令执行成功");
  • memerlukan perintah pemasangan install, tetapi projek itu belum diterbitkan ke npm, jadi buat sementara waktu, gunakan perintah npm link untuk mengaitkan perintah mycli dengan dunia global.

Jika anda melaksanakan baris arahan pada masa ini mycli, tiada lagi ralat akan dilaporkan.

Pembangunan praktikal nod alat baris arahan mycli

Konfigurasi skrip

fail test.js:

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

Kemudian Laksanakan mycli sekali lagi, dan tetingkap pop timbul ralat akan muncul

Pembangunan praktikal nod alat baris arahan mycli

Ini kerana melaksanakan perintah mycli adalah bersamaan dengan membenarkan komputer melaksanakan fail. , dan sistem komputer tidak dapat melaksanakan terus fail js , yang memerlukan kami menambah konfigurasi pada baris pertama kod skrip untuk menentukan program node.js pada komputer untuk melaksanakan skrip js fail.

#!/usr/bin/env node

Disebabkan menukar persekitaran pelaksanaan, anda perlu memadamkan fail yang dipautkan sebelum ini Lokasi fail mungkin C:Program Filesnodejsnode_modules dan padamkannya, dan kemudian laksanakan semula. myclinpm linkSekarang laksanakan

pada konsol dan anda boleh melihat bahawa konsol mencetak dengan betul.

mycli

Penggunaan kit alat berkaitan

    Baris arahan mengeluarkan fon berwarna-warni
  • Chalk
  • Kesan pemuatan, Serupa adalah perpustakaan kemajuan
  • Ora
  • arahan reka bentuk
  • commander
  • fungsi interaktif (seperti bertanya soalan...)
  • inquirer

Kapur

Pasang
npm install chalk@4.1.2 -S
Gunakan 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);

Pembangunan praktikal nod alat baris arahan mycli

Ora

Pasang
npm install ora@4.0.3 -S
Gunakan test.js
const ora = require("ora");

// ora
const spinner = ora({
  text: "安装中..."
});
spinner.start();
setTimeout(() => {
  // spinner.stop();
  spinner.succeed("安装成功");
  // console.log("安装成功");
}, 2000)
Api biasa
    • Mula memuatkan
    • start
    • Berhenti memuatkan
    • stop
    • Tamatkan pemuatan dan dibangunkan dengan gaya yang berjaya
    • succeed

Pembangunan praktikal nod alat baris arahan mycli

komander Perintah yang kerap digunakan dalam , seperti

vue -V dan arahan lain untuk melaksanakan arahan sedemikian, anda perlu menggunakan pustaka git --versionkomandervue create. Perintah yang diikuti dengan

dsb. boleh difahami sebagai parameter arahan Kemudian kita perlu mendapatkan parameter ini dan memproses peristiwa yang berbeza dengan menilai perbezaan dalam parameter. -V--helpDalam persekitaran

nod

, anda boleh mendapatkan parameter ini melalui . Pustaka komanderprocess.argv membantu kami merangkum beberapa kaedah tanpa perlu menilai arahan yang dibawa oleh input pengguna.

Pemasangan
npm install commander@8.2.0 -S
Gunakan
Selepas pemasangan selesai,
const commander = require("commander");
// ...
commander.parse(process.argv); // 放在后面
komander

akan Kami secara automatik dibekalkan dengan beberapa arahan, seperti , mari kita uji di bawah: --help

mycli --help
menyediakan kaedah untuk menetapkan nombor versi
Laksanakan
commander.version("1.0.0");
Anda boleh melihat bahawa konsol mencetak nombor versi

. mycli -V1.0.0

Kaedah arahan tersuai

commander.option(指令名, 描述, 回调函数)

Konfigurasikan beberapa fungsi yang ditulis di atas kepada perintah
    :
  • --init
Sekarang laksanakan ujian
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,可以看到我们刚才配置的指令和命令都出现在了帮助列表里。

Pembangunan praktikal nod alat baris arahan 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来进行判断。

Pembangunan praktikal nod alat baris arahan 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 命令:

Pembangunan praktikal nod alat baris arahan 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 教程

Atas ialah kandungan terperinci Pembangunan praktikal nod alat baris arahan mycli. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Artikel ini dikembalikan pada:juejin.cn. Jika ada pelanggaran, sila hubungi admin@php.cn Padam