不懂就问, Blob 类型,怎么通过 fileBinary 属性转化成 ArrayBuffer 的?

2020-09-16 18:14:34 +08:00
 yazoox

最近在修一个 legacy bug,看到一段不太懂的代码。

调用的是 dropbox 的 api (参考这个链接) https://www.dropbox.com/developers/documentation/http/documentation#files-download

这里的 dropbox 的文档就有点问题。该 API 的返回值,其实包含一个 property named fileBlob,类型是 Blob (在文档里面没有写出来)

我们就是通过这个 fileBlob 拿到下载文件的内容。

我们代码大约是:

async get(fileId: string): Promise<ArrayBuffer> {

“blabla...”

const fileData = await [dropbox SDK client API call]
return (fileData as any).fileBinary;

}

成功返回了。内容也都拿到了。但是,这里,我不理解的是, fileData 的类型是 dropbox.files.FileMetadata, 这个里面只有 property - fileBlob,类型是 Blob,没有 fileBinary 啊?这是怎么通过(fileData as any).fileBinary 转化成 ArrayBuffer 的?

更骚的是, 外面的调用者,直接通过下面这段来判断文件大小,也是成功的。

const fileData = await get("fileid");
(fileData as Buffer).length

google 了一些 ArrayBuffer, Blob, and Buffer 的相关资料,也没发现能够这样转换啊?

特来请教一下。有没有老司机 /大神解惑一下。

谢谢!

1674 次点击
所在节点    JavaScript
4 条回复
akatquas
2020-09-16 18:59:43 +08:00
yazoox
2020-09-17 08:09:32 +08:00
@akatquas
谢谢。清晰了好多。

dropbox 的 API 文档太坑了,这也不写,那也不写。fileBlob 没有写,fileBinary 也不写,还得去看源代码。
这一点,以前确实不知道: web & node 环境,这内容的返回类型还不同,blob or buffer,难道统一不好么?
还是说,因为技术限制 or 某些约定俗成 or best practice?
akatquas
2020-09-17 10:04:11 +08:00
@yazoox
浏览器环境里面没有 buffer,它使用了 [blob]( https://developer.mozilla.org/en-US/docs/Web/API/Blob) 来实现 的 二进制数据处理。

简单的说 blob 就是 浏览器下面的 buffer .
rioshikelong121
2020-09-17 12:34:30 +08:00
Blob 是对 ArrayBuffer 的高级抽象。ArrayBuffer 是 JS 操作二进制的基本机制。

具体可见: https://javascript.info/arraybuffer-binary-arrays

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/707656

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX