欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用node.js開發(fā)cli的完整步驟

 更新時(shí)間:2020年12月29日 09:35:48   作者:Harlan_Zhang  
這篇文章主要給大家介紹了關(guān)于如何利用node.js開發(fā)cli的完整步驟,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

CLI介紹

命令行界面(英語:command-line interface,縮寫:CLI),是在圖形用戶界面得到普及之前使用最為廣泛的用戶界面,它通常不支持鼠標(biāo),用戶通過鍵盤輸入指令,計(jì)算機(jī)接收到指令后,予以執(zhí)行。

目前前端開發(fā)中,CLI是常用的工具。前端三大框架Vue、React、Angular都有對(duì)應(yīng)的CLI,包括現(xiàn)在最流行的前端工程化的打包工具Webpack,也有對(duì)應(yīng)的webpack-cli。

在現(xiàn)代的前端開發(fā)中,CLI提高了開發(fā)的效率。讓相應(yīng)的前端開發(fā)者免去了大量的重復(fù)性操作,節(jié)省了大量的時(shí)間。CLI可以完成的功能,包括但不限于初始化生成對(duì)應(yīng)的項(xiàng)目模板、執(zhí)行特定的腳本文件、在項(xiàng)目中創(chuàng)建新的模塊 。下面來介紹一下前端工程師如何使用node.js來完成一個(gè)CLI。

創(chuàng)建項(xiàng)目

打開終端,創(chuàng)建moka-cli的目錄

mkdir moka-cli

進(jìn)入目錄,初始化項(xiàng)目

cd moka-cli
npm init -y

根目錄下新建bin目錄,并新建index.js文件,此時(shí)目錄結(jié)構(gòu)如下

|-- moka-cli
 |-- package.json
 |-- bin
  |-- index.js

開發(fā)cli需要借助commander、inquirer、chalk三個(gè)庫

npm install commander inquirer chalk --save

修改package.json文件,使用es moudle,并新增moka命令

package.json

{
 "name": "moka-cli",
 "version": "1.0.0",
 "description": "",
 "main": "index.js",
+ "type": "module",
+ "bin": {
+ "moka": "./bin/index.js"
+ },
 "scripts": {
 "test": "echo \"Error: no test specified\" && exit 1"
 },
 "keywords": [],
 "author": "",
 "license": "ISC",
 "dependencies": {
 "chalk": "^4.1.0",
 "commander": "^6.2.1",
 "inquirer": "^7.3.3"
 }
}

接下來需要在/bin/index.js中編程,在第一行添加如下代碼,這行代碼是告訴系統(tǒng)要用node來執(zhí)行這個(gè)文件。

#!/usr/bin/env node

再添加下面代碼

#!/usr/bin/env node

console.log('moka-cli run!')

然后在項(xiàng)目根目錄下全局安裝項(xiàng)目

npm install -g

到這里,一個(gè)簡單的CLI就完成了,可以打開終端,在任意目錄下輸入moka,控制臺(tái)就會(huì)打印出對(duì)應(yīng)的消息。

$ moka
moka-cli run!

第三方庫介紹

moka-cli希望實(shí)現(xiàn)可以創(chuàng)建前端開發(fā)模板的功能,可以使用moka命令來創(chuàng)建一個(gè)vue或react項(xiàng)目。

先來介紹一下使用到到第三方的庫

commander

文檔地址

用來實(shí)現(xiàn)命令的庫,在moka-cli中會(huì)用來實(shí)現(xiàn)create命令,實(shí)現(xiàn)用下面的命令行來創(chuàng)建一個(gè)vue-demo的項(xiàng)目

moka create vue vue-demo

inquirer

文檔地址

實(shí)現(xiàn)用戶和終端交互的庫,在moka-cli中使用create指令的時(shí)候會(huì)詢問是否覆蓋已有項(xiàng)目

$ moka create vue moka-demo
? Template named moka-demo is already existed, are you sure to overwrite? (Y/n)

chalk

文檔地址

可以在終端界面顯示出多種顏色的文本和背景

核心功能

在根目錄創(chuàng)建actions和templates目錄,目錄結(jié)構(gòu)如下

|-- moka-cli
 |-- package-lock.json
 |-- package.json
+ |-- actions
+ | |-- create.js
 |-- bin
 | |-- index.js
+ |-- templates
+  |-- react
+  | |-- app.js
+  | |-- index.js
+  | |-- src
+  |  |-- index.js
+  |-- vue
+   |-- app.js
+   |-- index.js
+   |-- src
+    |-- index.js

templats下面用來存放通過CLI要生成的項(xiàng)目的模板,在這里先隨便創(chuàng)建幾個(gè)文件展示一下。

修改/bin/index.js文件

#!/usr/bin/env node
import create from '../actions/create.js';
import commander from 'commander';

const { program } = commander;

program.version('0.0.1');

program
 .command('create <template> [name]')
 .description('新建項(xiàng)目')
 .action(create);

program.parse(process.argv);

修改./actions/create.js文件

import fs from 'fs';
import path from 'path';
import chalk from 'chalk';
import inquirer from 'inquirer';

import { fileURLToPath } from 'url';

const __filename = fileURLToPath(import.meta.url);
const __dirname = path.dirname(__filename);
const TEMPLATES = ['vue', 'react'];

const targetPath = process.cwd();

function createTemplate(template, name) {
 const templatePath = path.join(__dirname, '../', `templates/${template}`);

 function readAndCopyFile(parentPath, tempPath) {
 let files = fs.readdirSync(parentPath);

 files.forEach((file) => {
  let curPath = `${parentPath}/${file}`;
  let stat = fs.statSync(curPath);
  let filePath = `${targetPath}/${tempPath}/${file}`;
  if (stat.isDirectory()) {
  fs.mkdirSync(filePath);
  readAndCopyFile(`${parentPath}/${file}`, `${tempPath}/${file}`);
  } else {
  const contents = fs.readFileSync(curPath, 'utf8');
  fs.writeFileSync(filePath, contents, 'utf8');
  }
 });
 }

 readAndCopyFile(templatePath, name);
}

function deleteTemplate(path) {
 if (fs.existsSync(path)) {
 fs.readdirSync(path).forEach(function (file, index) {
  var curPath = path + '/' + file;
  if (fs.lstatSync(curPath).isDirectory()) {
  // recurse
  deleteTemplate(curPath);
  } else {
  // delete file
  fs.unlinkSync(curPath);
  }
 });
 fs.rmdirSync(path);
 }
}

export default function create(template, name) {
 if (!TEMPLATES.includes(template)) {
 console.log(chalk.red(`No ${template} Template`));
 return;
 }

 const projectPath = path.resolve(targetPath, name);

 if (fs.existsSync(projectPath)) {
 inquirer
  .prompt([
  {
   name: 'template-overwrite',
   type: 'confirm',
   message: `Template named ${name} is already existed, are you sure to overwrite?`,
   validate: function (input) {
   if (input.lowerCase !== 'y' && input.lowerCase !== 'n') {
    return 'Please input y/n !';
   } else {
    return true;
   }
   },
  },
  ])
  .then((answers) => {
  // 如果確定覆蓋
  if (answers['template-overwrite']) {
   // 刪除文件夾
   deleteTemplate(projectPath);
   console.log(chalk.yellow(`Template already existed , removing!`));
   //創(chuàng)建新模塊文件夾
   fs.mkdirSync(projectPath);
   createTemplate(template, name);
   console.log(
   chalk.green(`${template} template has been created successfully!`)
   );
  }
  })
  .catch((err) => {
  console.log(chalk.red(err));
  });
 } else {
 fs.mkdirSync(projectPath);
 createTemplate(template, name);
 console.log(
  chalk.green(`${template} template has been created successfully!`)
 );
 }
}

最后在項(xiàng)目根目錄運(yùn)行以下命令,重新安裝一下moka-cli

npm install -g

隨便找一個(gè)路徑,運(yùn)行moka create <template> [name]命令來生成項(xiàng)目

moka create react react-demo

效果如下,會(huì)在該目錄下生成一個(gè)react-demo的文件夾,里面存放的就是moka-cli項(xiàng)目中/templates/react下的所有

$ moka create react react-demo
react template has been created successfully!

如果在該目錄下繼續(xù)創(chuàng)建一個(gè)同名的項(xiàng)目,就會(huì)提示是否覆蓋,輸入y后繼續(xù)執(zhí)行

$ moka create react react-demo
? Template named react-demo is already existed, are you sure to overwrite? Yes
Template already existed , removing!
react template has been created successfully!

create命令的核心邏輯是通過node的fs模塊來復(fù)制/templates下的文件,然后將其放到指定的路徑下,具體實(shí)現(xiàn)直接看代碼就可以來。

總結(jié)

CLI是提示前端開發(fā)效率的重要工具,如果有長期維護(hù)的項(xiàng)目,開發(fā)一個(gè)CLI來完成一些重復(fù)性的工作,是一個(gè)不錯(cuò)的選擇。

moka-cli還沒有上傳github,等過段時(shí)間完善一些/templates下的項(xiàng)目模板,我會(huì)在文章里補(bǔ)充項(xiàng)目地址。

到此這篇關(guān)于利用node.js開發(fā)cli的文章就介紹到這了,更多相關(guān)node.js開發(fā)cli內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • windows下安裝nodejs及框架express

    windows下安裝nodejs及框架express

    express是一個(gè)開源的node.js框架,初學(xué)者使用express可以快速的搭建一個(gè)Web項(xiàng)目,express中已經(jīng)集成了Web的http服務(wù)器創(chuàng)建、請(qǐng)求和文件管理以及Session的處理等功能,所以express是非常適合初學(xué)者的入門學(xué)習(xí),這篇文章通過兩種方式介紹windows下安裝nodejs及框架express
    2015-08-08
  • Node.js中的進(jìn)程間通信

    Node.js中的進(jìn)程間通信

    這篇文章主要介紹了Node.js中的進(jìn)程間通信,文章圍繞主題展開詳細(xì)的內(nèi)容戒殺,具有一定的參考價(jià)值,感興趣的小伙伴可以參考一下
    2022-09-09
  • electron demo項(xiàng)目npm install安裝失敗的解決方法

    electron demo項(xiàng)目npm install安裝失敗的解決方法

    下面小編就為大家分享一篇electron demo項(xiàng)目npm install安裝失敗的解決方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-02-02
  • Node.js入門教程:在windows和Linux上安裝配置Node.js圖文教程

    Node.js入門教程:在windows和Linux上安裝配置Node.js圖文教程

    這篇文章主要介紹了Node.js入門教程:在windows和Linux上安裝配置Node.js的方法,本文圖文并茂,步驟明細(xì),是學(xué)習(xí)安裝node.js的絕佳教程,需要的朋友可以參考下
    2014-08-08
  • Node.js發(fā)出請(qǐng)求走Proxyman代理調(diào)試tip詳解

    Node.js發(fā)出請(qǐng)求走Proxyman代理調(diào)試tip詳解

    這篇文章主要為大家介紹了Node.js發(fā)出請(qǐng)求走Proxyman代理調(diào)試tip詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-08-08
  • NodeJs生成sitemap站點(diǎn)地圖的方法示例

    NodeJs生成sitemap站點(diǎn)地圖的方法示例

    這篇文章主要介紹了NodeJs生成sitemap站點(diǎn)地圖的方法示例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Node.js程序中的本地文件操作用法小結(jié)

    Node.js程序中的本地文件操作用法小結(jié)

    這篇文章主要介紹了Node.js程序中的本地文件操作用法小結(jié),作為運(yùn)行在服務(wù)器端的JavaScript解釋器,Node中自然擁有操作本地文件的方法,需要的朋友可以參考下
    2016-03-03
  • node.js文件上傳處理示例

    node.js文件上傳處理示例

    這篇文章主要介紹了node.js文件上傳處理的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下。
    2016-10-10
  • node.js 使用 net 模塊模擬 websocket 握手進(jìn)行數(shù)據(jù)傳遞操作示例

    node.js 使用 net 模塊模擬 websocket 握手進(jìn)行數(shù)據(jù)傳遞操作示例

    這篇文章主要介紹了node.js 使用 net 模塊模擬 websocket 握手進(jìn)行數(shù)據(jù)傳遞操作,結(jié)合實(shí)例形式分析了node.js基于net模塊模擬 websocket握手相關(guān)原理及進(jìn)行數(shù)據(jù)傳遞具體操作技巧,需要的朋友可以參考下
    2020-02-02
  • node.js之基礎(chǔ)加密算法模塊crypto詳解

    node.js之基礎(chǔ)加密算法模塊crypto詳解

    這篇文章主要介紹了node.js之基礎(chǔ)加密算法模塊crypto詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-09-09

最新評(píng)論