iofs/Readme.md

120 lines
2.2 KiB
Markdown
Raw Normal View History

2017-02-26 17:46:04 +08:00
![module info](https://nodei.co/npm/iofs.png?downloads=true&downloadRank=true&stars=true)
# iofs
2019-07-16 15:03:53 +08:00
> `iofs`是一个基于原生`fs`模块封装的工具, 旨在提供更加方便实用一些常用的API方法(同步), API习惯参考了`bash shell`, 习惯用命令行的朋友, 可能会比较亲切。
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
## 属性
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
### origin
> 返回原生的`fs`模块对象, 方便调用一些未封装的额外功能
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
## APIs
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
### .cat(file)
- file `<String>` 文件路径
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
> 读取文件, 返回一个`Buffer对象`
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
### .ls(path, recursion)
2017-02-26 17:46:04 +08:00
- path `<String>`
2019-07-16 15:03:53 +08:00
- recursion `<Boolean>`
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
> 列出指定目录下的所有文件&目录, 不包括 '.' and '..'. 结果返回一个数组.
> 如果参数`recursion`设为ture, 则会递归遍历所有子目录.
2017-02-26 17:46:04 +08:00
### echo(data, file[, append][, encode])
- data `<String>` | `<Buffer>` | `<Number>`
- file `<String>`
- append `<Boolean>` optional
- encode `<String>` optional
2019-07-16 15:03:53 +08:00
> 写数据到指定文件中. 如果指定文件不存在, 则自动生成.
> 如果`append`设为true, 则往文件后面追加数据, 不会覆盖.
> `encode`为指定编码, 默认utf8.
2017-02-26 17:46:04 +08:00
```javascript
2019-07-16 15:03:53 +08:00
var fs = require('iofs')
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
fs.echo('hello ', 'test.txt') // 如果test.txt存在, 则覆盖.
2017-02-26 17:46:04 +08:00
2019-07-16 15:03:53 +08:00
fs.echo('world', 'test.txt', true) // 不会覆盖, 只会追加到 test.txt中
2017-02-26 17:46:04 +08:00
```
### chmod(file, mode)
- file `<String>` | `<Buffer>`
- mode `<Integer>`
2019-07-16 15:03:53 +08:00
> 修改文件&目录的权限.
2017-02-26 17:46:04 +08:00
```javascript
2019-07-16 15:03:53 +08:00
fs.chmod('test.txt', 777)
2017-02-26 17:46:04 +08:00
```
### mv(from, to)
- from `<String>`
- to `<String>`
2019-07-16 15:03:53 +08:00
> 移动文件, 支持跨磁盘移动; 同时具备重命名功能。
2017-02-26 17:46:04 +08:00
### cp(from, to)
- from `<String>`
- to `<String>`
2019-07-16 15:03:53 +08:00
> 复制文件.
2017-02-26 17:46:04 +08:00
### rm(path, recursion)
- path `<String>`
- recursion `<Boolean>`
2019-07-16 15:10:21 +08:00
> 删除文件, 如果要删除目录&子目录, `recursion`必须设为true.
2017-02-26 17:46:04 +08:00
```javascript
fs.rm('./foo/test.txt')
fs.rm('./foo', true)
```
### stat(path)
- path `<String>`
2019-07-16 15:03:53 +08:00
> 返回文件的状态信息, 如修改时间, 文件大小等
2017-02-26 17:46:04 +08:00
### isdir(path)
- path `<String>`
2019-07-16 15:03:53 +08:00
> 判断指定目录是否为一个目录, 路径不存在或者不是目录都会返回 false.
2017-02-26 17:46:04 +08:00
### mkdir(path)
- path `<String>`
2019-07-16 15:03:53 +08:00
> 创建目录, 可自动创建上级目录(如不存在)
2017-02-26 17:46:04 +08:00
### exists(path)
- path `<String>`
2019-07-16 15:03:53 +08:00
> 判断文件&目录是否存在