当前位置: 首页 > news >正文

uniapp——App下载文件,打开文档(一)

uniapp如何下载文件、打开文件

文章目录

    • uniapp如何下载文件、打开文件
      • 下载文件
        • 下载文件成功返回数据格式
      • 打开文档
      • 处理` iOS` 打开文件可能失败问题

相关API:

  • uni.downloadFile
  • uni.openDocument

注意:

  • 只支持 GET 请求,需要 POST的,可以看另一篇文章;
  • 打开文档:不支持H5;
  • 为了方便测试,这里没有封装,自行抽取即可;
  • 只测试APP Android端,其他设备没有细测;

下载文件

在各个小程序平台运行时,网络相关的 API 在使用前需要配置域名白名单。在h5上是跨域的,用户需要处理好跨域问题。

  • 通过 uni.downloadFile 结合 uni.openDocument 实现;
  • 下载成功后,直接打开文档,没有做保存操作;
  • 如需监听下载进度:调用 onProgressUpdate
downloadFile() {// 头部信息根据实际情况填写let header = {Authorization: getToken()}uni.downloadFile({url: 'xxx/export', // 下载资源的 urlheader,success: (res) => {const { statusCode, tempFilePath } = res;console.log('下载成功--->', res);if (statusCode == 200) {this.openDocument(tempFilePath);}},fail: (err) => {uni.showToast({title: '下载失败',icon: 'error'})}})
}

下载文件成功返回数据格式
  • 返回文件的本地临时路径
{"tempFilePath": "_doc/uniapp_temp_1735636109698/download/export","statusCode": 200,"errMsg": "downloadFile:ok"
}

打开文档

openDocument(filePath) {filePath = this.fileNameEscape(filePath)uni.openDocument({filePath,showMenu: true, // 右上角是否有可以转发分享的功能fileType: 'xlsx', // 文件类型,有效值 doc, xls, ppt, pdf, docx, xlsx, pptx,success: (res) => {uni.showToast({title: '打开文档成功'})},fail: (err) => {uni.showToast({title: '打开文档失败',icon: 'error'})}})
},

处理 iOS 打开文件可能失败问题

  • 下载文件名中包含中文字符时会失败情况
fileNameEscape(filename) {if (uni.getSystemInfoSync().platform == "ios") {filename = escape(filename);}return filename;
},
http://www.lryc.cn/news/514319.html

相关文章:

  • Python 列表的高级索引技巧
  • UE5.3 虚幻引擎 Windows插件开发打包(带源码插件打包、无源码插件打包)
  • RC充电电路仿真与分析
  • C++ 设计模式:观察者模式(Observer Pattern)
  • 栈及栈的操作
  • 算法:切饼
  • C++ 设计模式:代理模式(Proxy Pattern)
  • JDK、JRE、JVM的区别
  • 2021年福建公务员考试申论试题(县级卷)
  • 问题记录:[FATAL] [1735822984.951119148]: Group ‘manipulator‘ was not found.
  • 【大模型实战篇】Mac本地部署RAGFlow的踩坑史
  • iOS 修改图片颜色
  • OceanBase到MySQL实时同步方案
  • 信息系统项目管理师——第8章章 项目整合管理 笔记
  • 最好用的图文识别OCR -- PaddleOCR(1) 快速集成
  • Unity制作3D场景的脑电运动想象范式(左右手抓握)
  • python23-常用的第三方库01:request模块-爬虫
  • CAT3D: Create Anything in 3D with Multi-View Diffusion Models 论文解读
  • 持续学习入门
  • 天猫推荐数据集实践
  • 《Vue3实战教程》33:Vue3路由
  • 【大模型系列】MultiUI(2024.11)
  • 「Mac畅玩鸿蒙与硬件52」UI互动应用篇29 - 模拟火车票查询系统
  • Dubbo 核心知识全解析:原理、流程与关键机制
  • 时间序列预测算法---LSTM
  • 二十三种设计模式-建造者模式
  • MarkDown 的 mermaid gantt(甘特图)、mermaid sequenceDiagram (流程图) 语法解析和应用
  • git submodule的使用:将别人的git仓库作为自己的子仓库
  • Springboot 下载附件
  • MySQL 延迟复制:确保数据安全与系统稳定的秘诀