博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
写一个自用的前端脚手架
阅读量:4083 次
发布时间:2019-05-25

本文共 973 字,大约阅读时间需要 3 分钟。

在工作中我们会用到很多便捷的脚手架工具,比如Vue的vue-cli,React的create-react-app等。极大的提高了我们的工作效率,那么今天我们就来学学怎么制作一款自用的前端脚手架。

核心依赖

  1. commander 命令行工具
  2. download-git-repo git仓库代码下载
  3. chalk 命令行输出样式美化
  4. Inquirer.js 命令行交互
  5. ora 命令行加载中效果
  6. didyoumean 脚本命令匹配
  7. fs-extra fs的替代品。
  8. log-symbols 日志着色
  9. semver 语义化日志控制
  10. validate-npm-package-name 校验包名

项目结构

写一个自用的前端脚手架

 

项目搭建

  1. 在一个空文件下执行npm init
  2. 将以上依赖全部安装,执行npm install commander ... validate-npm-package-name -S

1.初始化

在根目录下新建`bin/luchx.js`文件,并添加以下代码

写一个自用的前端脚手架

 

首先文件第一行表示该文件运行于node环境,接着引入commander。最后的program.parse方法用于解析命令行中传入的参数。

2.添加第一个指令

command命令有两种用法,官方示例如下:

写一个自用的前端脚手架

 

其中参数对应的<>, [ ]分别代表必填和选填。这里我们使用第一种,添加如下代码:

写一个自用的前端脚手架

 

3.添加监听--help事件

写一个自用的前端脚手架

 

执行结果

写一个自用的前端脚手架

 

交互说明

1.在根目录下创建lib文件,并添加create.js文件。

写一个自用的前端脚手架

 

2.校验包名

写一个自用的前端脚手架

 

3. inquirer.js 处理命令交互

写一个自用的前端脚手架

 

4. 封装下载文件lib/downloadFromRemote.js

写一个自用的前端脚手架

 

5. 添加下载操作

写一个自用的前端脚手架

 

运行

本项目没有发布到npm上,仅作学习研究之用,可以自己拉取项目然后执行npm link,在本地体验。为了可以全局使用,我们需要在package.json里面设置一下,这样就可以执行luchx命令开头的指令了。

"bin": { "luchx": "bin/luchx.js"},

以上完整的代码可以访问[github查看获取](https://github.com/luchx/ECHI_CLI)

参考

  • vue-cli Vue.js 开发的标准工具
  • commander node.js 命令行接口的完整解决方案
  • Inquirer 命令行交互工具

转载地址:http://txqni.baihongyu.com/

你可能感兴趣的文章
TBUS的一些信息
查看>>
PX4+激光雷达在gazebo中仿真实现(古月居)
查看>>
专业和业余的区别就在于你在基础在基本功打磨练习花的时间
查看>>
通过mavlink实现自主航线的过程笔记
查看>>
Ardupilot飞控Mavlink代码学习
查看>>
这些网站有一些嵌入式面试题合集
查看>>
我觉得刷题是有必要的,不然小心实际被问的时候懵逼,我觉得你需要刷个50份面试题。跟考研数学疯狂刷卷子一样!
查看>>
我觉得嵌入式面试三要素:基础吃透+项目+大量刷题,缺一不可。不刷题是不行的。而且得是大量刷,刷出感觉套路,别人做题都做得是固定题型套路条件反射了,你还在那慢慢理解慢慢推是不行的,也是考研的教训。
查看>>
相机标定的目的:获取摄像机的内参和外参矩阵(同时也会得到每一幅标定图像的选择和平移矩阵),内参和外参系数可以对之后相机拍摄的图像就进行矫正,得到畸变相对很小的图像。
查看>>
现在来看,做个普罗米修斯的docker镜像对我而言并不难,对PX4仿真环境配置也熟悉了。
查看>>
删除docker容器和镜像的命令
查看>>
VINS-Fusion Intel® RealSense™ Depth Camera D435i
查看>>
使用Realsense D435i运行VINS-Fusion并建图
查看>>
gazebo似乎就是在装ROS的时候一起装了,装ROS的时候选择的是ros-melodic-desktop-full的话。
查看>>
React + TypeScript 实现泛型组件
查看>>
TypeScript 完全手册
查看>>
React Native之原理浅析
查看>>
Git操作清单
查看>>
基础算法
查看>>
前端面试
查看>>