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

小程序附件下载并预览功能

一、实现的功能:

1、word、excel、图片等实现下载并预览

2、打开文件后显示文件名称

二、代码:

// 判断文件类型whatFileType(url) {let sr = url.lastIndexOf("."); //  最后一次出现的位置let fileType = url.substr(sr + 1); // 截取url的类型return fileType;},// 下载文件/*** 本地文件存储的大小限制为 10M*/handleDownloadFile(e) {let fileTypes = ["doc", "docx", "xls", "xlsx", "ppt", "pptx", "pdf"];let imageTypes = ["jpg", "jpeg", "png"];let fileType = this.whatFileType(e.target.dataset.fileurl);let fileName = imageTypes.includes(fileType) ? "" : e.target.dataset.name;const timestamp = Date.parse(new Date());wx.showLoading({title: "加载中",});wx.getSavedFileList({// 获取文件列表success(res) {res.fileList.forEach((val, key) => {// 遍历文件列表里的数据// 删除存储的垃圾数据wx.removeSavedFile({filePath: val.filePath,});});},});wx.downloadFile({url: e.target.dataset.fileurl,filePath: fileTypes.includes(fileType)? wx.env.USER_DATA_PATH + "/" + timestamp + fileName: wx.env.USER_DATA_PATH + "/" + "." + fileType,method: "GET",success: function (res) {if (fileTypes.includes(fileType)) {wx.openDocument({filePath: res.filePath,showMenu: true,flieType: fileType,success: function (res) {wx.hideLoading();},fail: function (err) {wx.hideLoading();},});} else if (imageTypes.includes(fileType)) {wx.hideLoading();wx.previewImage({showmenu: true,current: res.filePath, // 当前显示图片的http链接urls: [res.filePath], // 需要预览的图片http链接列表});} else {wx.hideLoading();wx.showModal({title: "提示",content: "文件类型不支持预览",showCancel: false,});}},fail: function (err) {wx.hideLoading();wx.showToast({title: "下载超时",icon: "none",});},});},

http://www.lryc.cn/news/99908.html

相关文章:

  • 数据库缓存服务——NoSQL之Redis配置与优化
  • 【雕爷学编程】MicroPython动手做(13)——掌控板之RGB三色灯
  • .Net Core上传组件_.Net Core图片上传组件_Uploader7.0
  • Exadata磁盘损坏导致磁盘组无法mount恢复(oracle一体机磁盘组异常恢复)---惜分飞
  • 左值引用与右值引用的区别?右值引用的意义?
  • 2023年深圳杯数学建模D题基于机理的致伤工具推断
  • Vue的router学习
  • Inpaint Anything: 自动化抹除视频元素
  • Flutter 开发者工具 Android Studio 开发Flutter应用
  • 后端byte[]传给前端接收默认变成string字符串
  • UE5 动画蓝图模板(Animation Blueprint Template)
  • Log4j源码解析
  • Docker 容器访问宿主机服务
  • Go 发送邮件
  • Spring AOP 的概念及其作用
  • python基础1——环境安装
  • uniapp 中 的progress加载进度条 的使用,在 页面显示数据加载的进度条,使用户的使用体验效果更好
  • 【尚硅谷】第01章:随堂复习与企业真题(Java语言概述)
  • MyBatis的SqlSession理解
  • axios 某个接口使用自己独有的完整地址
  • WEB:Web_python_template_injection
  • 【Android安全】Embedded Trace Microcell模块
  • 修改内核驱动之后-如何给内核打补丁
  • 【javaSE】 类和对象详解
  • 大数据课程D5——hadoop的Sink
  • 【数据结构】27.移除元素
  • 机器学习分布式框架ray运行xgboost实例
  • C++设计模式笔记
  • 简单聊聊创新与创造力
  • 使用TensorFlow训练深度学习模型实战(上)