首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在React Native中使用apisauce下载pdf文件?

如何在React Native中使用apisauce下载pdf文件?
EN

Stack Overflow用户
提问于 2021-05-08 01:33:40
回答 1查看 60关注 0票数 0

我正在使用apisauce来处理基本的http请求,比如GET和POST,它工作得很好。现在我需要能够下载pdf文件了。有没有可能配上蜂酱?如果是这样的话,谁有一些示例代码?

EN

回答 1

Stack Overflow用户

发布于 2021-05-08 02:50:22

我对apisauce不太确定,但从互联网上的url下载pdf,

我更喜欢使用这个包:,因为它很稳定,并且有很好的文档。

请按照以下步骤操作:

在终端(MAC/Linux)或

  1. 中运行以下命令

纱线添加rn-fetch-blob

  1. 如果使用CocoaPods,请将pod添加到Podfile

pod 'rn-fetch-blob',:路径模块‘../node_ => /rn-fetch-blob’

  1. .js.tsx file中导入包
  2. 在下载函数中添加以下代码,并使用下载按钮调用函数is download

if (Platform.OS === 'android') ==>

代码语言:javascript
复制
        RNFetchBlob.config({
          fileCache: false,
          addAndroidDownloads: {
            useDownloadManager: true,
            notification: true,
            mime: 'application/pdf',
            path:
              `/storage/emulated/0/Download/${file_name}.pdf`,
          },
        })
          .fetch('GET', api, {'Cache-Control': 'no-store'})
          .then((res) => {})
          .catch((errorMessage, statusCode) => {}); 

if (Platform.OS === 'ios')

代码语言:javascript
复制
      const {
        dirs: {DownloadDir, DocumentDir},
      } = RNFetchBlob.fs;
      const fPath = `${DocumentDir}/${file_name}.pdf`;
      RNFetchBlob.config({
        fileCache: true,
        path: fPath,
        notification: true,
        appendExt: 'pdf',
      })
        .fetch('GET', api, {
          Authorization: 'Token ' + token,
        })
        .then(async (resp) => {
          RNFetchBlob.fs.writeFile(fPath, resp.data, 'base64');
          RNFetchBlob.ios.previewDocument(fPath);
        });
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67439415

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档