我正在使用RNFetchBlob将图像从本地(ios)文件系统上传到Firebase

尽管我的映像已被删除,但是关闭它后,我的Blob仍保留在文件系统中。
我尝试取消链接Blob,但它仍然存在

function createBlob(uri, mediaType) {
  const Blob = RNFetchBlob.polyfill.Blob;
  const typePrefix = isImage(mediaType) ? 'image' : 'video';
  window.Blob = Blob;
  window.XMLHttpRequest = RNFetchBlob.polyfill.XMLHttpRequest;

  return new Promise((resolve, reject) => {
    const uid = guid();
    const mediaRef = firebase.storage().ref('users').child(`${uid}.${mediaType}`);
    let uploadBlob = null;

    Blob.build(uri, { type: `${typePrefix}/${mediaType}` })
    .then((blob) => {
      uploadBlob = blob;
      return mediaRef.put(blob, { type: `${typePrefix}/${mediaType}` });
    })
    .then((response) => {
      uploadBlob.close();

      resolve(response);
    })
    .catch(error => {
      reject(error);
    });
  });
}


这是关闭Blob后在我的模拟器文件夹中的外观

javascript - close()之后未删除RNFetchBlob blob-LMLPHP

createBlob之后,我要使用RNFetchBlob.fs.unlink(path)从本地存储中删除文件

最佳答案

我不认为您正在使用close(),因为uploadBlob变量是在上一个闭包中创建的,但没有传递给下一个.then块。我认为这可能有效...

Blob.build(uri, { type: `${typePrefix}/${mediaType}` })
.then((blob) => {
  uploadBlob = blob;
  return ({
     response: mediaRef.put(blob, { type: `${typePrefix}/${mediaType}` }),
     blob: uploadBlob
})
.then(({response, blob}) => {
  blob.close();

  resolve(response);
})

10-02 07:18