vue文件下载功能通过和后端对接接口实现
实现目标:点击下载按钮,浏览器下方出现下载的文件,word文件将下载为word文件格式,不会进行pdf的转换。
实现效果:
实现方法:
1.后端swagger中:
2.api的js文件中:
-
export function planDownloadById(param) {
-
return request({
-
url: '/xxxx/xxxx/download',
-
method: 'post',
-
data: param,
-
responseType: 'blob', // 必须要写
-
headers: {
-
'Content-Type': 'application/json;charset=UTF-8'
-
}
-
});
-
}
3.vue文件中:
引入api文件中的下载接口
import { planDownloadById } from '@/api/xxxx/index'
template中:
-
<template slot-scope="scope">
-
<el-button @click="downloadPlan(scope.row)" type="text" size="small" style="margin-right: 20px">
-
<i class="el-icon-download"></i>
-
下载
-
</el-button>
-
</template>
methods中:
-
downloadPlan(row) {
-
// 下载文件的名称
-
let filePathArray = row.filePath.split('/')
-
let fileName = filePathArray[filePathArray.length - 1]
-
// 参数拼接
-
let param = new FormData()
-
param.append('id', row.id)
-
// 调用接口
-
planDownloadById(param).then((res) => {
-
if (res.status == 200) {
-
const link = document.createElement('a') // 创建a标签
-
const blo = new Blob([res.data], { type: res.data.type }) // 设置下载格式
-
link.style.display = 'none'
-
const url = window.URL.createObjectURL(blo)
-
link.href = url
-
link.setAttribute('download', fileName)
-
document.body.appendChild(link)
-
link.click() // 触发下载
-
window.URL.revokeObjectURL(url) // 释放掉blob对象
-
document.body.removeChild(link)
-
this.refreshData() // 刷新页面
-
} else {
-
this.$message.warning('请稍后再试')
-
}
-
})
-
},
这样就实现了文件的下载功能。
这篇好文章是转载于:学新通技术网
- 版权申明: 本站部分内容来自互联网,仅供学习及演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,请提供相关证据及您的身份证明,我们将在收到邮件后48小时内删除。
- 本站站名: 学新通技术网
- 本文地址: /boutique/detail/tanhggeiek
系列文章
更多
-
photoshop保存的图片太大微信发不了怎么办
PHP中文网 06-15 -
《学习通》视频自动暂停处理方法
HelloWorld317 07-05 -
Android 11 保存文件到外部存储,并分享文件
Luke 10-12 -
word里面弄一个表格后上面的标题会跑到下面怎么办
PHP中文网 06-20 -
photoshop扩展功能面板显示灰色怎么办
PHP中文网 06-14 -
微信公众号没有声音提示怎么办
PHP中文网 03-31 -
excel下划线不显示怎么办
PHP中文网 06-23 -
excel打印预览压线压字怎么办
PHP中文网 06-22 -
TikTok加速器哪个好免费的TK加速器推荐
TK小达人 10-01 -
怎样阻止微信小程序自动打开
PHP中文网 06-13