2022/01/[Varlet]进阶篇:好用的工具(下)/index

前言

在上篇《进阶篇:好用的工具(上)》中,我们已经介绍了一部分工具。

在这文中,我们将介绍剩下的那些工具。

注意:以下所有示例均以 Macos 环境为例

execa

通过这个工具,我们可以在代码里执行命令行指令。

安装

1
npm install execa

使用

1
2
3
4
const execa = require('execa')

execa('git',['--version']).stdout.pipe(process.stdout);
execa('node',['-v']).stdout.pipe(process.stdout);

image.png

有关Node知识的一些介绍可以看一下《基础篇:Node知识储备》
在本文中为了方便演示 我们使用5.1.1版本

我们甚至可以用来做一些git操作

1
execa('git',['clone','https://github.com/varletjs/varlet.git']).stdout.pipe(process.stdout);

讲到这里,相信聪明的你已经想到了一个最简单的实现cli的方式,那就是通过命令行直接从远端将项目模板拉过来

对应的git命令可以使用

1
2
3
git clone -b [branch] [repo url] [folderName/user input]

execa('git',['clone','-b','dev','https://github.com/varletjs/varlet.git','niubi']);

ora

在项目创建的过程中,难免会遇到等待的情况。

以上面我们执行git clone为例,详细不少小伙伴们已经尝试过了,是不是发现在clone的过程中一点提示都没有,体验上非常的不友好。

这个时候我们就可以使用ora来加上一个过程动画。

安装

1
npm install ora

使用

我们依旧以上面git clone为例

1
2
3
4
5
6
const ora = require('ora');
const execa = require("execa");

const spinner = ora(`Loading,please wait for a moment`).start();
await execa('git',['clone','-b','dev','https://github.com/varletjs/varlet.git','niubi'])
spinner.succeed('Loaded succeed')

当你的命令行中出现如下的这样一个小东西的时候,说明你的ora已经成功运作了

image.png

加载完成提示

image.png

fs-extra

node本身提供了fs模块,但用起来多有不便。

相比较而言fs-extra这个库用起来就方便多了,添加了未包含在原生fs模块中的文件系统方法,并向fs方法添加了promise支持。不过需要使用node的版本为10.12.0版本或以上。

在祖师爷的vue-next中也使用了此库

安装

1
npm install fs-extra

常见用法

copy 复制

1
2
3
4
fs.copy('myfile.js', 'mynewfile.js', err => {
if (err) return console.error(err)
console.log('success!')
})

image.png

ensureDir 创建目录

确保目录的存在。如果目录结构不存在,就创建一个。

1
fs.ensureDir('./src')

image.png

createWriteStream 可写流

1
2
const writer =  fs.createWriteStream('./myfile.txt')
writer.write('Hello')

image.png

这个时候就有细心的小伙伴发现了,我们改变要写的内容,每次都会将全部内容重写,那如何才能接在已有的内容后继续写入呢?

别急,这不就来了嘛~

1
2
const writer =  fs.createWriteStream('./myfile.txt',{ flags:'a' })
writer.write(' Varlet')

image.png

outputFile 写入文件

这个方法乍一看与writeFile类似,区别在于,当要写入的文件不存在时,该方法会创建一个目标文件。

1
2
fs.outputFile('mynewfile.txt', 'hello varlet!')
fs.outputFile('anotherfile.txt', 'hello varlet!')

image.png

remove 删除

1
2
3
4
fs.remove('anotherfile.txt', function(err) {
if (err) return console.error(err)
console.log("success!")
})

image.png

pathExists 路径检查

1
2
3
4
5
6
7
8
9
fs.pathExists('index.js', (err, exists) => {
if (err) return console.log(err);
console.log(exists);
});

fs.pathExists('anotherfile.txt', (err, exists) => {
if (err) return console.log(err);
console.log(exists);
});

image.png

readdir 读取文件目录

1
2
3
4
fs.readdir('src',(err,files)=>{
if(err) return console.log(err);
console.log(files)
})

image.png

slash

用于转换 Windows 反斜杠路径转换为正斜杠路径 \ => /

安装

1
npm install slash

使用

1
2
3
4
5
6
7
const string = path.join('foo', 'bar');
// Unix => foo/bar
// Windows => foo\bar

slash(string);
// Unix => foo/bar
// Windows => foo/bar

hash-sum

超快的独特哈希生成器。

祖师爷的vue-next中我们也可以看到此库的身影

安装

1
npm i hash-sum -S

使用

1
2
3
const hash = require('hash-sum');

hash(value)

varlet-cli中我们用它来处理style scoped

chokidar

我们使用chokidar来监控文件变化

安装

1
npm install chokidar

使用

1
2
3
chokidar.watch('.').on('all', (event, path) => {
console.log(event, path);
});

image.png

详细已经有聪明的小伙伴联想到了dev模式下,我们完成文件的改动会完成服务的重启,其实正是利用了这个工具库

最后

以上,有关cli用到的工具的介绍先告一段落, 更多的用法可以见各工具的官方文档。

参考文档 execa,ora,chokidar,fs-extra,hash-sum,slash

文章作者: Joker
文章链接: https://qytayh.github.io/2022/01/[Varlet]%E8%BF%9B%E9%98%B6%E7%AF%87%EF%BC%9A%E5%A5%BD%E7%94%A8%E7%9A%84%E5%B7%A5%E5%85%B7(%E4%B8%8B)/index/
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议。转载请注明来自 Joker's Blog