Seb*_*rth 3 javascript json blob arraybuffer
我有一个 Javascript 对象,它将由一个带有参数和子对象的非循环对象层次结构组成。其中一些对象可能保存从文件加载或通过 XHR 接收的二进制数据(如果 Blob、ArrayBuffer 或其他东西尚未定义)。
通常我会使用 JSON.stringify() 将它序列化为 JSON 但我如何指定二进制数据将被 base64 编码?
那么你会推荐我什么二进制数据对象(Blob,ArrayBuffer,...)?
编辑:除普通 JSON 之外的其他数据格式不是一种选择。
对于 blob,事先将对象中的 blob 转换为 base64,然后对对象进行字符串化更有意义。这是因为没有可靠的方法将 blob 同步转换为 base64,因此替换函数在这里不是一个可行的选择。
const blobToBase64 = (blob) => {
return new Promise((resolve) => {
const reader = new FileReader();
reader.readAsDataURL(blob);
reader.onloadend = function () {
resolve(reader.result);
};
});
};
(async () => {
const b64 = await blobToBase64(blob);
const jsonString = JSON.stringify({blob: b64});
console.log(jsonString);
})();
Run Code Online (Sandbox Code Playgroud)
从解析的 JSON 中获取 blob 就像这样简单
const parsed = JSON.parse(jsonString);
const blob = await fetch(parsed.blob).then(res => res.blob());
console.log(blob);
Run Code Online (Sandbox Code Playgroud)
JSON.stringify确实通过两种可能的解决方案做到了这一点:
a)调用replacer函数来决定如何序列化一个值。
function replacer(key, value) {
if (typeof value === "string") {
return undefined;
}
return value;
}
var foo = {foundation: "Mozilla", model: "box", week: 45, transport: "car", month: 7};
var jsonString = JSON.stringify(foo, replacer);
Run Code Online (Sandbox Code Playgroud)
b)toJSON()为该对象定义一个成员函数。
var obj = {
foo: 'foo',
toJSON: function () {
return '{ "foo": "' + + '" }';
}
};
JSON.stringify(obj); // '{ "foo": "Zm9v" }'
Run Code Online (Sandbox Code Playgroud)
如果这也适合您,请转发此评论。
| 归档时间: |
|
| 查看次数: |
15553 次 |
| 最近记录: |