buffer/README.md

79 lines
2.4 KiB
Markdown
Raw Permalink Normal View History

2024-05-30 12:01:34 +08:00
## Buffer
2024-05-30 12:51:59 +08:00
浏览器版的 Buffer 对象模拟, 提供近似 Node.js 的 BUffer 对象的 API。
2024-05-30 12:01:34 +08:00
2024-05-30 12:26:36 +08:00
[![@bytedo/buffer](https://img.shields.io/npm/v/@bytedo/buffer.svg)](https://www.npmjs.com/package/@bytedo/buffer)
### 文档
2024-05-30 12:51:59 +08:00
> 以下方法的 encoding, 如无特殊说明, 均只支持`utf8`(默认),`base64`, `hex`, `binary`4 种。
2024-05-30 12:26:36 +08:00
#### 静态方法
##### Buffer.from(data, offsetOrEncoding, end)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 支持从数组/字符串等值中创建 Buffer 对象。
2024-05-30 12:26:36 +08:00
##### Buffer.alloc(len, str, encoding)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 创建指定字节长度的 Buffer, 同时填充内容。
2024-05-30 12:26:36 +08:00
##### Buffer.concat(list, totalLength)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 合并多个 Buffer 对象, 可指定总字节长度。
2024-05-30 12:26:36 +08:00
##### Buffer.isBuffer(target)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 判断指定值是否为 Buffer 对象。
2024-05-30 12:26:36 +08:00
##### Buffer.compare(buf1, buf2)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 比较 2 个 Buffer 对象, 通常用于排序中, 返回`-1/0/1`。
2024-05-30 12:26:36 +08:00
##### Buffer.byteLength(data, encoding)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 返回给定内容的字节长度, 内容可以是任意类型。
2024-05-30 12:26:36 +08:00
#### 实例方法
##### .toString(encoding, start, end)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 将`Buffer`对象转为字符串。 其中`encoding`支持`utf8`(默认),`base64`, `hex`, `binary`4 种。
2024-05-30 12:26:36 +08:00
##### .fill(val, start, end, encoding)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 向 Buffer 对象中填充内容, 可填充到指定位置。
2024-05-30 12:26:36 +08:00
##### .copy(target, targetStart, sourceStart, sourceEnd)
2024-05-30 12:51:59 +08:00
向目标对象中复制当前对象, 注意, 该方法改变的不是自身, 是传入的对象, 这个行为与`Node.js`版一致。
2024-05-30 12:26:36 +08:00
##### .write(val, offset, len, encoding)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 指定位置写入数据, 可以是任意类型。
2024-05-30 12:26:36 +08:00
##### .compare(buf)
2024-05-30 12:51:59 +08:00
与静态方法的功能一样, 只是这里比较的对象是自身, 返回`-1/0/1`。
2024-05-30 12:26:36 +08:00
##### .equals(buf)
2024-05-30 12:51:59 +08:00
2024-05-30 12:26:36 +08:00
与`Node.js`版基本一致, 判断与给定的对象是否一致, 返回`true/false`。
##### .includes(data, offset, encoding)
2024-05-30 12:51:59 +08:00
与`Node.js`版基本一致, 判断给定内容是否包含在内, 可从指定位置开始判断, 返回`true/false`。
### 其他操作
Buffer 对象, 可以直接用于创建文件对象, 如下
```js
let file = new File([Buffer.from('这是一段文本')], 'demo.txt', {
type: 'text/plain'
})
console.log(file)
```
但是由于浏览器端暂不支持非异步的方法将`Blob/File`对象转成`ArrayBuffer`, 所以暂时不支持从`Blob/File`中创建`Buffer`对象.