赞
踩
uni.downloadFile({ url:url,//调接口返回url success:(res)=>{ uni.hideLoading(); if(res.statusCode==200){ var tempFilePath = res.tempFilePath; saveFile(tempFilePath); }else{ uni.showToast({ icon:'none', title:'报告下载失败' }) } }, fail:err=>{ uni.hideLoading(); uni.showToast({ icon:'none', title:'报告下载失败' }) reject(err); } })
saveFile(tempFilePath){//保存到本地 //文件保存到本地 uni.saveFile({ tempFilePath:tempFilePath,//临时路径 success:res=>{ uni.showToast({ icon:'none', mask:true, title:'文件已保存'+res.savedFilePath,//保存路径 duration:3000 }) setTimeOut(()=>{ //打开文档查看 uni.openDocument({ filePath:res.savedFilePath, success:res=>{ console.log('打开文档成功'); } }) },3000) } }) }
//打开文档查看
uni.openDocument({
filePath:res.savedFilePath,
success:res=>{
console.log('打开文档成功');
}
})
uni.downloadFile({ url:url,//调接口返回的url success:res=>{ uni.hideLoading(); if(res.statusCode==200){ var tempFilePath = res.tempFilePath; window.open(tempFilePath); //saveFile(tempFilePaht); }else{ uni.showToast({ icon:'none', title:'报告下载失败' }) } }, fail:err=>{ uni.hideLoading(); uni.showToast({ icon:'none', title:'报告下载失败' }) reject(err); } })
saveFile(url){//保存到本地 try{ const fileName = '报告名称'; //new Blob 实例化文件流 //let url = fileData //const url = window.URL.createObjectURL(new Blob([fileData],{type:'application/pdf'})) const link = document.createElement('a'); link.style.display = 'none'; link.href = url; link.setAttribute('download',fileName); document.body.appendChild(link); link.click(); //下载完成移除元素 document.body.removeChild(link); //释放掉blob对象 window.URL.revokeObjectURL(url) uni.showToast({ title:'下载成功' }) }catch(error){ uni.showToast({ title:'下载失败' }) } }
h5浏览文件直接后台给文件地址即可。
以上内容摘自https://blog.csdn.net/panfu163/article/details/132832484
以上代码并未通过验证,后续使用到,有问题的话会补充。
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。