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
|
|
|
|
2020-01-08 21:20:25 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
## API
|
|
|
|
+ props
|
|
|
|
- [origin](#origin)
|
|
|
|
+ methods
|
2020-01-09 11:44:26 +08:00
|
|
|
- [.cat(file)](#catfile)
|
|
|
|
- [.ls(path, recursive)](#lspath-recursive)
|
|
|
|
- [.echo(data, file, append, encode)](#echodata-file-append-encode)
|
|
|
|
- [.chmod(path, mode)](#chmodpath-mode)
|
|
|
|
- [.chown(path, uid, gid)](#chownpath-uid-gid)
|
|
|
|
- [.mv(origin, target)](#mvorigin-target)
|
|
|
|
- [.cp(origin, target)](#cporigin-target)
|
|
|
|
- [.rm(origin)](#rmorigin)
|
|
|
|
- [.stat(path)](#statpath)
|
|
|
|
- [.isdir(path)](#isdirpath)
|
2020-09-21 16:57:40 +08:00
|
|
|
- [.isfile(path)](#isfilepath)
|
2020-01-09 11:44:26 +08:00
|
|
|
- [.mkdir(dir, mode)](#mkdirdir-mode)
|
|
|
|
- [.exists(path)](#existspath)
|
2020-09-21 16:57:40 +08:00
|
|
|
- [.is(path)](#isspath-mode)
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
|
2019-07-16 15:03:53 +08:00
|
|
|
## 属性
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
### origin
|
2019-07-16 15:03:53 +08:00
|
|
|
> 返回原生的`fs`模块对象, 方便调用一些未封装的额外功能
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2019-07-16 15:03:53 +08:00
|
|
|
## APIs
|
2020-09-21 16:57:40 +08:00
|
|
|
> 所有API均支持在最后传入一个 `debug<Boolean>`参数(v1.3.2新增), 用于打印错误日志
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
### .cat(file)
|
2019-07-16 15:03:53 +08:00
|
|
|
> 读取文件, 返回一个`Buffer对象`
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-08 21:20:25 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| file | `<String>` | 是 | 要读取的文件路径 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
### .ls(path, recursive)
|
2019-07-16 15:03:53 +08:00
|
|
|
> 列出指定目录下的所有文件&目录, 不包括 '.' and '..'. 结果返回一个数组.
|
2020-01-08 21:20:25 +08:00
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>` | 是 | 要读取的目录 |
|
|
|
|
| recursive | `<String>` | 否 | 是否递归读取 |
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
### .echo(data, file, append, encode)
|
|
|
|
> 写数据到指定文件中. 如果指定文件不存在, 则自动生成.
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| data | `<String>` `<Buffer>` `<Number>` | 是 | 要写入的数据, 可以字符串、Buffer对象, 数字 |
|
|
|
|
| file | `<String>` | 是 | 要写入的文件名, 不存在会自动创建, 如存在会覆盖 |
|
|
|
|
| append | `<Boolean>` | 否 | 是否在文件后追加数据, 默认否, 即会整个文件替换 |
|
|
|
|
| encode | `<String>` | 否 | 指定保存的编码, 默认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存在, 则覆盖.
|
|
|
|
fs.echo('world', 'test.txt', true) // 不会覆盖, 只会追加到 test.txt中
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
```
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .chmod(path, mode)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 修改文件&目录的权限.
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要修改的文件&目录路径 |
|
|
|
|
| mode | `<Number>` | 是 | 权限码 `0o000 - 0o777` |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
fs.chmod('test.txt', 0o777)
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
```
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .chown(path, uid, gid)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 修改文件&目录的归属。
|
2020-01-09 20:22:08 +08:00
|
|
|
>> `v1.3.0 新增`
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要修改的文件&目录路径 |
|
|
|
|
| uid | `<Number>` | 是 | 用户ID |
|
|
|
|
| gid | `<Number>` | 是 | 用户组ID |
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .mv(origin, target)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 移动文件&目录, 支持跨磁盘移动; 同时具备重命名功能。
|
2020-01-09 20:22:08 +08:00
|
|
|
>> `v1.3.0 之后支持对目录进行操作`
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| origin | `<String>`| 是 | 要移动或重命名的文件&目录 |
|
|
|
|
| target | `<String>` | 是 | 目标文件名&目录名 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .cp(origin, target)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 复制文件&目录, 支持跨磁盘复制。
|
2020-01-09 20:22:08 +08:00
|
|
|
>> `v1.3.0 之后支持对目录进行操作`
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| origin | `<String>`| 是 | 要复制的文件&目录 |
|
|
|
|
| target | `<String>` | 是 | 目标文件名&目录名 |
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .rm(origin)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 删除文件&目录
|
2020-01-09 20:22:08 +08:00
|
|
|
>> `v1.3.0 之后取消第2个参数, 改为自动判断是否目录, 是否自动递归删除`
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| origin | `<String>`| 是 | 要删除的文件&目录 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
```javascript
|
|
|
|
|
|
|
|
fs.rm('./foo/test.txt')
|
2020-01-09 10:46:35 +08:00
|
|
|
fs.rm('./foo') // 整个目录删除
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
```
|
|
|
|
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
|
|
|
|
|
|
|
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .stat(path)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 返回文件&目录的状态信息, 如修改时间, 文件大小等
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要读取的目录&文件 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .isdir(path)
|
2019-07-16 15:03:53 +08:00
|
|
|
> 判断指定目录是否为一个目录, 路径不存在或者不是目录都会返回 false.
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要读取的目录路径 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-09-21 16:57:40 +08:00
|
|
|
### .isfile(path)
|
|
|
|
> 判断指定目录是否为一个文件, 路径不存在或者不是文件都会返回 false
|
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要读取的文件 |
|
|
|
|
|
|
|
|
---
|
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .mkdir(dir)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 创建目录, 会自动创建上级目录(如不存在)
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| dir | `<String>`| 是 | 要创建的目录名 |
|
2017-02-26 17:46:04 +08:00
|
|
|
|
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
---
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 11:44:26 +08:00
|
|
|
### .exists(path)
|
2020-01-09 10:46:35 +08:00
|
|
|
> 判断文件&目录是否存在
|
2017-02-26 17:46:04 +08:00
|
|
|
|
2020-01-09 10:46:35 +08:00
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
2020-09-21 16:57:40 +08:00
|
|
|
| path | `<String>`| 是 | 要读取的目录&文件 |
|
|
|
|
|
|
|
|
|
|
|
|
---
|
|
|
|
|
|
|
|
### .is(path, mode)
|
|
|
|
> 判断文件&目录是否存在
|
|
|
|
|
|
|
|
| 参数 | 类型 | 是否必须 | 说明 |
|
|
|
|
| :--: | :--: | :--: | -- |
|
|
|
|
| path | `<String>`| 是 | 要读取的目录&文件 |
|
|
|
|
| mode | `<Number>`| 否 | 如 r: 4, w: 2, rw: 6 |
|
|
|
|
|
|
|
|
|