用Npm构建一个简单的命令行工具

2024-09-01 19:48

本文主要是介绍用Npm构建一个简单的命令行工具,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原文章链接:请戳

Npm构建一个简单的命令行工具

在团队开发过程中,你是用什么工具去调用private package的呢?最常见的答案就是:使用命令行工具来使用它。我们用两部分来介绍如何制作其中一款命令行工具。


场景一:轻松部署GitHub pages

部署项目通常比较繁琐,因此我们使用自动化来完成部署任务。目前,有很多的task runners都可以为我们自动化构建任务,但是最简单的一种方式就是npm run scripts
本章中,我们用构建一个GitHub page的例子来演示,当然我们也可以使用这种方式去部署其他服务,例如Heroku、AWS。或者你可以将它作为一个private package发布,里面包含公司内部代码以及配置选项。

npm run scripts

首先,你定义一段可以被执行的字符串指令,当你调用脚本的时候,在命令行汇中执行npm run scripts,例如,我们为一个脚本命名为patch-release

#package.json
{"name": "index","version": "1.0.1","scripts": {"patch-release": "npm version patch && npm publish && git push --follow-tags"}
}

这里写图片描述

当你执行patch-release的时候,它会通过npm version来修改package.json中的version并且提交更新,然后发布到npm,接着push到GitHub。
如果你在dependenciesdevDependencies配置项中提前设置了modules,你就可以不用在将依赖包设置为全局,它们将是可以直接使用的。并且你也可以在scripts中使用其他的脚本npm run scripts

用脚本发布页面

git-it启发,我们用脚本来部署到GitHub pages,构建步骤如下:

"scripts": {"build": "...","git-commit": "git add -A . && git commit -a -m 'gh-pages update'","git-push": "git push origin gh-pages --force && git checkout master","deploy": "npm run build && npm run git-commit && npm run git-push"},

然后,在我们想要部署的时候,运行npm run deploy即可。

还有更好的方式吗?

这种方式很棒。这将意味着你可以不用去记住那些冗长的字符串指令,以及他们对应的flags。然而,你想按照这种方式部署到其他项目又得大量copy&paste。这将意味着在你的项目中又得大量重复您的代码。
那么,我们怎么才能遵循”don’t repeat yourself”原则呢?我们可以尝试创建一个module,它可以将多个字符串指令合并成为一条指令。这就是说我们在不同的项目里面,可以很轻松的使用和维护这些指令还能分享给团队。
详情参见:戳这里

Step1: 创建一个基本的命令行界面

首先,我们创建一个基本的Common line interface(也称做CLI)。

  1. 创建一个package 清单
    package 清单(即‘package.json’ 文件),它里面含有基本信息,例如包名称(package name),版本号(version)。
    如果你想给你的package限定使用范围,供你的内部团队使用时,你可以考虑使这个包成为private package,设定的范围应该是你的用户名。

    $ npm init --scope=xxx
  2. 创建一个可被执行的脚本文件
    因为我们想要运行命令行,但是前提是我们需要用一个解释器去启动文件(有时候我们称为shebang line)

    
    #! ./node/env nodeconsole.log('console.log output')

现在我们运行测试一下:node bin/commit.js
3. 告诉命令行你的命令是什么
我们想要执行一条命令,那么我们首先得告诉Node如何才能找到能被执行的文件,我们吧这条指令命名为github-pages-commit。同时,我们在package.json文件中添加一个关键字:bin。

{"bin": {"github-pages-commit": "bin/commit.js"}
}
  1. 确保命令可用
    为了测试你的命令被拾取到,使用npm link来执行关联操作,这将确保你的指令(github-pages-commit)是可以被正确执行的。

step2: 执行被提交的命令

现在我们已经验证了一个能被执行的CLI,我们可以添加我们的命令了。
npm run scripts 使用很方便,因为你可以很轻松在命令行中使用指令。在可复用的模块中执行这些脚本很便捷,否则,我们的团队就不能确保那些脚本重用。
我们将使用shelljs模块来实现,或者你也可以使用node‘s child_process,但是使用shelljs有一个好处就是,你可以在window系统中使用大量的unix指令。具体参考文档: 请戳这里。
1. 将shelljs 作为依赖

$ npm install --save shelljs

将会在package.json文件中被添加为依赖(dependency)
2. 测试 shll.exec() 运行正常
为了确保我们掌握shell.exec()如何工作,我们将添加一个简单的输出声明到 bin/commit.js


#! /node/env node$ var shell = require('shelljs')
shell.exec('echo shell.exec works')
  1. 使github-pages-commit 执行一个提交
    为此,我们在命令行中简单的添加一个命令,用它来执行一次提交
    
    #! ./node/node$ var shell = require('shelljs')
    shell.exec("git add -A . && git commit -a -m 'update' ")

为了测试这个,打开另一个命令行窗口并转到您使用GitHub页面的repo进行更改,然后运行github-pages-commit。在运行git log之后,您应该看到提交消息的提交gh-pages update。

step3: 添加其他两个命令

  1. 添加 bin/push/js

    
    # /user/bin/env node$ var shell = require('shelljs')
    $ shell.exec('git push origin master --force')
  2. 添加 bin/deploy.js
    我们通过定义过的其他指令进行合并

    
    #! /node/env nodevar shell = require("shelljs")
    shell.exec("github-pages-commit && github-pages-push")
  3. 映射指令文件

    {"github-pages-commit":"bin/commit.js","github-pages-push":"bin/push.js","githuv-pages-deploy":"bin/deploy.js"
    }
  4. 再次执行npm link
    您需要npm link再次运行,以便它将创建两个新的符号链接。
    现在您可以进行其他更改并运行github-pages-deploy以测试完整的任务。

step4: 发布你的package

如果你之前从未发布过软件包,请戳这里
因为这是一个有作用域的包,如果你想公开发布,必须使用access选项,了解更多请戳这里

npm publish --access=publish

最后,付费会员可以发布private package。

step5: 将你的命令添加为npm run scripts

我们可以告诉我们的团队在全局安装这个模块,然后所有的指令都将可以在命令行中运行,我们不需要用npm 运行脚本,但是全局安装有两个缺点:首先,在新同事着手一个项目的时候他得体检做一些准备工作,其次,当项目依赖更新的时候,你的团队成员必须也要更新全局模块。
相反,我们要使它的一个devDependencies在package.json为我们要部署的项目。通过这种方式,当新开发人员npm install开始运行项目时会下载它,并且每次开发人员运行时都会进行更新npm update。

$ npm install --save-dev @xxx/github-pages-deploy

现在您可以将可复用命令添加为npm运行脚本

{"scripts":{"build": "....","deploy": "github-pages-deploy"}
}

TO BE CONTINUE…

这篇关于用Npm构建一个简单的命令行工具的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1127884

相关文章

csu 1446 Problem J Modified LCS (扩展欧几里得算法的简单应用)

这是一道扩展欧几里得算法的简单应用题,这题是在湖南多校训练赛中队友ac的一道题,在比赛之后请教了队友,然后自己把它a掉 这也是自己独自做扩展欧几里得算法的题目 题意:把题意转变下就变成了:求d1*x - d2*y = f2 - f1的解,很明显用exgcd来解 下面介绍一下exgcd的一些知识点:求ax + by = c的解 一、首先求ax + by = gcd(a,b)的解 这个

hdu2289(简单二分)

虽说是简单二分,但是我还是wa死了  题意:已知圆台的体积,求高度 首先要知道圆台体积怎么求:设上下底的半径分别为r1,r2,高为h,V = PI*(r1*r1+r1*r2+r2*r2)*h/3 然后以h进行二分 代码如下: #include<iostream>#include<algorithm>#include<cstring>#include<stack>#includ

嵌入式QT开发:构建高效智能的嵌入式系统

摘要: 本文深入探讨了嵌入式 QT 相关的各个方面。从 QT 框架的基础架构和核心概念出发,详细阐述了其在嵌入式环境中的优势与特点。文中分析了嵌入式 QT 的开发环境搭建过程,包括交叉编译工具链的配置等关键步骤。进一步探讨了嵌入式 QT 的界面设计与开发,涵盖了从基本控件的使用到复杂界面布局的构建。同时也深入研究了信号与槽机制在嵌入式系统中的应用,以及嵌入式 QT 与硬件设备的交互,包括输入输出设

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

usaco 1.3 Prime Cryptarithm(简单哈希表暴搜剪枝)

思路: 1. 用一个 hash[ ] 数组存放输入的数字,令 hash[ tmp ]=1 。 2. 一个自定义函数 check( ) ,检查各位是否为输入的数字。 3. 暴搜。第一行数从 100到999,第二行数从 10到99。 4. 剪枝。 代码: /*ID: who jayLANG: C++TASK: crypt1*/#include<stdio.h>bool h

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

uva 10387 Billiard(简单几何)

题意是一个球从矩形的中点出发,告诉你小球与矩形两条边的碰撞次数与小球回到原点的时间,求小球出发时的角度和小球的速度。 简单的几何问题,小球每与竖边碰撞一次,向右扩展一个相同的矩形;每与横边碰撞一次,向上扩展一个相同的矩形。 可以发现,扩展矩形的路径和在当前矩形中的每一段路径相同,当小球回到出发点时,一条直线的路径刚好经过最后一个扩展矩形的中心点。 最后扩展的路径和横边竖边恰好组成一个直

poj 1113 凸包+简单几何计算

题意: 给N个平面上的点,现在要在离点外L米处建城墙,使得城墙把所有点都包含进去且城墙的长度最短。 解析: 韬哥出的某次训练赛上A出的第一道计算几何,算是大水题吧。 用convexhull算法把凸包求出来,然后加加减减就A了。 计算见下图: 好久没玩画图了啊好开心。 代码: #include <iostream>#include <cstdio>#inclu

uva 10130 简单背包

题意: 背包和 代码: #include <iostream>#include <cstdio>#include <cstdlib>#include <algorithm>#include <cstring>#include <cmath>#include <stack>#include <vector>#include <queue>#include <map>

用命令行的方式启动.netcore webapi

用命令行的方式启动.netcore web项目 进入指定的项目文件夹,比如我发布后的代码放在下面文件夹中 在此地址栏中输入“cmd”,打开命令提示符,进入到发布代码目录 命令行启动.netcore项目的命令为:  dotnet 项目启动文件.dll --urls="http://*:对外端口" --ip="本机ip" --port=项目内部端口 例: dotnet Imagine.M