下载按钮点击一次却下载两个文件问题

今天碰到一个问题,创建一个下载模板按钮,平平无奇的功能代码如下

ini 复制代码
`
<!--template -->
...
       <DButton
            v-for="(templateUrl, index) in templateUrls"
            :key="index"
            link
            type="primary"
            :icon="Download"
            @click="templateUrl.url()"
          >
            {{ templateUrl.label }}
          </DButton>
  ...        
          
<!--js-->
    url: async () => {
  try {
    // const blob = await (serversApis.servers as any).knowledgeQaTemplate({ responseType: 'blob' })
    // // 兼容 axios 封装:可能直接返回 Blob 或 { data: Blob }
    // const data: Blob = (blob instanceof Blob) ? blob : (blob?.data ?? blob)
    // const url = URL.createObjectURL(data)
    // const a = document.createElement('a')
    // a.href = url
    // a.download = '问答导入模板.xlsx'
    // document.body.appendChild(a)
    // a.click()
    // a.remove()
    // URL.revokeObjectURL(url)
    //this is right code,no need to create a.click()
    await (serversApis.servers as any)
    .knowledgeQaTemplate({ responseType: 'blob' })
  }
  catch (e) {
    ElMessage.error('模板下载失败')
    // 控制台打印方便排查
    console.error('knowledgeQaTemplate 下载失败:', e)
  }

},`

看日志也是事件和请求只执行了一次,好一顿找,最后发现是响应头有这个:

Content-Disposition:attachment;filename*=%E7%9F%A5%E8%AF%86%E5%BA%93%E9%97%AE%E7%AD%94%E5%AF%BC%E5%85%A5%E6%A8%A1%E6%9D%BF.xlsx

所以直接改方法只执行请求方法即可:

url: async () => { try { // const blob = await (serversApis.servers as any).knowledgeQaTemplate({ responseType: 'blob' }) // // 兼容 axios 封装:可能直接返回 Blob 或 { data: Blob } // const data: Blob = (blob instanceof Blob) ? blob : (blob?.data ?? blob) // const url = URL.createObjectURL(data) // const a = document.createElement('a') // a.href = url // a.download = '问答导入模板.xlsx' // document.body.appendChild(a) // a.click() // a.remove() // URL.revokeObjectURL(url) //this is right code,no need to create a.click() await (serversApis.servers as any) .knowledgeQaTemplate({ responseType: 'blob' }) } catch (e) { ElMessage.error('模板下载失败') // 控制台打印方便排查 console.error('knowledgeQaTemplate 下载失败:', e) } },

完美!!!!

相关推荐
晚风予星5 小时前
Ant Design Token Lens 迎来了全面升级!支持在 .tsx 或 .ts 文件中直接使用 Design Token
前端·react.js·visual studio code
sunny_5 小时前
⚡️ vite-plugin-oxc:从 Babel 到 Oxc,我为 Vite 写了一个高性能编译插件
前端·webpack·架构
GIS之路5 小时前
ArcPy 开发环境搭建
前端
林小帅6 小时前
【笔记】OpenClaw 架构浅析
前端·agent
林小帅7 小时前
【笔记】OpenClaw 生态系统的多语言实现对比分析
前端·agent
程序猿的程7 小时前
开源一个 React 股票 K 线图组件,传个股票代码就能画图
前端·javascript
不爱说话郭德纲7 小时前
告别漫长的HbuilderX云打包排队!uni-app x 安卓本地打包保姆级教程(附白屏、包体积过大排坑指南)
android·前端·uni-app
唐叔在学习8 小时前
[前端特效] 左滑显示按钮的实现介绍
前端·javascript
用户5282290301808 小时前
【学习笔记】ECMAScript 词法环境全解析
前端
青青家的小灰灰8 小时前
React 架构进阶:自定义 Hooks 的高级设计模式与最佳实践
前端·react.js·前端框架