uni.base64ToArrayBuffer(base64)
时间: 2023-11-16 21:44:22 浏览: 323
uni.base64ToArrayBuffer(base64)是uniapp提供的一个方法,用于将base64字符串转换为ArrayBuffer对象。它在处理二进制数据时非常有用,可以将base64字符串转换为二进制数据进行操作。在你的情况下,你遇到的问题是后端返回的是二进制流,而uniapp无法直接接收二进制流。因此,你可以利用uni.base64ToArrayBuffer(base64)将后端返回的base64字符串转换为二进制数据,然后进行进一步的处理或操作。
相关问题
uni.base64ToArrayBuffer(base64) 的使用
uni.base64ToArrayBuffer(base64) 是在uni-app框架中用于将 base64 字符串转换为 ArrayBuffer 的方法。
使用方法如下:
1. 引入 uni-app 的基础库:`import uni from 'uni'`。
2. 调用 `uni.base64ToArrayBuffer(base64)` 方法,并传入需要转换的 base64 字符串作为参数。
示例代码如下:
```javascript
import uni from 'uni'
// 假设需要转换的 base64 字符串为 base64Str
const base64Str = 'cGFzc3dvcmQ='
// 调用 uni.base64ToArrayBuffer() 方法
const buffer = uni.base64ToArrayBuffer(base64Str)
console.log(buffer) // 输出 ArrayBuffer 对象
```
执行以上代码后,`buffer` 变量即为转换后的 ArrayBuffer 对象,可以根据需求进行后续处理。
注意:在使用该方法前,请确保已经正确引入 uni-app 的基础库,并且 `base64` 参数为有效的 base64 字符串。
plus.io.resolveLocalFileSystemURL(videoRes.tempFilePath, entry => { entry.file(function (file: PlusIoFile) { if (!plus.io.FileReader) { throw new Error('FileReader is not available') } const reader = new plus.io.FileReader(); reader.onloadend = async e => { // Get data let base64 = e.target.result.split(',')[1]; const arrayBuffer = uni.base64ToArrayBuffer(base64); // 转换为arrayBuffer格式 const res = await multiPartUpload(arrayBuffer, { filename: file.name || '', size: file.size as number, type: file.type || '', }) await addFile(res) }; reader.readAsDataURL(file) }, function (e: any) { throw new Error(e.message); }); })视频模糊
这段代码是用于处理视频文件的模糊问题。它使用了plus.io模块中的resolveLocalFileSystemURL方法来获取视频文件的本地URL。然后通过file方法获取到文件对象,并使用FileReader来读取文件内容。读取完成后,将读取到的数据转换为base64格式,并使用uni.base64ToArrayBuffer方法将base64数据转换为arrayBuffer格式。最后,将arrayBuffer数据通过multiPartUpload方法进行多部分上传,并将上传完成的结果通过addFile方法进行处理。如果出现错误,则会抛出相应的错误信息。
阅读全文