摘要:命令行也有苦恼不知身为前端的你是不是还在使用开发反正我是。每次都从桌面到工作目录中去,双击完事。在上一家公司做应用的时候,对也是深恶痛绝。最后无不以文件收尾。的由来前些时间接触到一个管理的,叫,用起来真是爽。也可以使用的形式自己添加。
命令行也有苦恼
不知身为前端er的你是不是还在使用 Windows 开发?反正我是。使用 Git?使用 npm scripts?好吧,命令行是少不了的吧?想必很多同学和我一样,使用 Git Bash 作为命令行终端吧。
可是每次都要敲,累不累?想想一次简单的 Git 提交需要几个步骤?
$ git add -A $ git commit -m "commit" $ git push
图简便的你可能会在 package.json 中这样配置:
{ // ... "scripts": { // ... "push": "git add -A && git commit -m "commit" && git push" } } // ...
然后再敲 npm run push。啊啊心好累。
用过 browser-sync cli 吗?反正为了图简便,我是经常用的。敲过最{{BANNED}}的是下面这一行:
browser-sync start --server --files "dist/*" --index "dist/index.html" --open "external" --reload-debounce --no-notify.bat/.sh 的故事
敲过一次之后,发誓再也不这么玩了。索性在桌面保存了一个 bs.bat 文件,把上面的内容放进去。每次都从桌面 copy 到工作目录中去,双击完事。
后来玩 github 稍微勤了一些,commit、pull 的时候,命令行敲起来固然爽得不行,可是累啊。在上一家公司做 react-native 应用的时候,对 react-native run start cd android && ./gradlew assembleRelease 也是深恶痛绝。最后无不以 bat、sh文件收尾。
nshm 的由来前些时间接触到一个管理 npm registry 的 package,叫 nrm,用起来真是爽。nrm use taobao nrm add xx url简单就能解决问题。这让我萌生一个想法:能不能不要每次都从桌面 copy 那些简单的脚本啊,来个简单的命令行自己把文件写目录不就 OK 了吗?
酝酿了一段时间。迟迟不肯动手。今天中午下楼抽烟,灵机一动,思路来了,花了半下午时间,边写边重构,最终做出来一个略嫌简陋但还能凑合用的工具,名之曰 “nshm”,取 “Node.js .sh scripts Manager” 的缩写,放在 Github 上了,https://github.com/AngusFu/nshm。
使用起来很简单,看文档就行。
安装$ npm install nshm -g $ nshm添加一条自定义命令[args...]
$ nshm add多个命令合并成一条命令-[t|f] [text|path] # add file content $ nshm add commit --file ./my-commit.sh # or $ nshm add commit -f ./my-commit.sh # add text content $ nshm add pull --text "git pull" # or $ nshm add pull -t "git pull"
$ nshm co删除缓存的命令[command|text] [command|text] [command|text] [...] $ nshm co git commit pull "git status"
$ nshm rm清除所有缓存的命令<...> $ nshm rm commit pull git
$ nshm clean列出现有的命令
# view all names $ nshm ls # view all details $ nshm ls -aExample 01
$ nshm add add -t "git add -A" $ nshm add commit -t "git commit -m "push"" $ nshm add pull -t "git push" $ nshm co git add commit pull # init my directory # then we"ll get `add.sh` `commit.sh` `pull.sh` $ nshm gitExample 02
# browserSync cli # here we use `${}` as placeholders # for necessary params $ nshm add bs -t "browser-sync start --server --files "${files}" --index "${index}" --open "external" --reload-debounce --no-notify" # now we get the `bs.sh` file under our working directory $ nshm bs --file "**" --index "index.html"结尾
工具默认自带了 Git 相关的 commit pull 及集成两者的 git 命令,还有上面提到的 browser-sync 的命令(简称作bs)。也可以使用 nshm add 的形式自己添加。
微不足道的工具,自娱自乐一下,虽然显得 low 了点,也能解决自己的一点问题。
That"s all。
PS: 今晚开始看 WebRTC 的内容,小有收获,学习笔记会放在 https://github.com/AngusFu/webRTC-demo 这里,不是对书上 demo 的简单重复,而是按照自己的理解来记录。学习的生活捡起来!
文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。
转载请注明本文地址:https://www.ucloud.cn/yun/80008.html
摘要:修改增加注意中的应为你的项目名称,应为你的服务器公网。配置完之后重启,使上面的配置项生效。安装添加下面链接中的源,然后安装番外安装如果已经下了想升级成的朋友可执行以下代码把之前的掉安装现在的 版本:ubuntu 14.04(64位) 1.安装 Nginx(version:1.9) 1、首先添加nginx_signing.key wget http://nginx.org/keys/ng...
摘要:修改增加注意中的应为你的项目名称,应为你的服务器公网。配置完之后重启,使上面的配置项生效。安装添加下面链接中的源,然后安装番外安装如果已经下了想升级成的朋友可执行以下代码把之前的掉安装现在的 版本:ubuntu 14.04(64位) 1.安装 Nginx(version:1.9) 1、首先添加nginx_signing.key wget http://nginx.org/keys/ng...
摘要:安装执行版本号,例如以下语句可以安装几的版本好像在墙内只能找到以前的版本使用可以查看现有的版本,可以支持模糊切换。 一直说要好好学习,总结知识什么的。一直觉得没有时间。周一终于提交了论文盲审。决定从今天每周都总结一次自己的所学。希望自己能坚持。 任务描述: 一个医学系的同学要分析一个叫TCGA的数据库,每个实验文件是txt,格式如下: hsa-miR-1228* 5.185500...
阅读 833·2021-11-25 09:43
阅读 3660·2021-11-19 09:40
阅读 861·2021-09-29 09:34
阅读 1756·2021-09-26 10:21
阅读 852·2021-09-22 15:24
阅读 4150·2021-09-22 15:08
阅读 3230·2021-09-07 09:58
阅读 2588·2019-08-30 15:55