JS下载或导出文件的三种方法

编程入门 行业动态 更新时间:2024-10-15 16:19:13

JS下载或导出文件的<a href=https://www.elefans.com/category/jswz/34/1770022.html style=三种方法"/>

JS下载或导出文件的三种方法

方案1使用axios请求后端接口

// 假设在一个列表里面选中行,单个或多个,选中
handleEmplabelExport (selectRow) {let employeeIds = selectRow.map(item => item.employeeId)let params = {employeeIds: employeeIds || null,...this.searchForm}
  /* 下载方案1 */axios({method: 'post',url: '/emp/employee/export/empLabel', // 请求地址data: params, // 参数responseType: 'blob'}).then(res => {// let newName = name// 处理返回的文件流const content = res.dataconst blob = new Blob([content], { type: 'application/octet-stream;charset=ISO8859-1' })console.log(res.headers)const fileName = decodeURIComponent((res.headers['content-disposition']).split('filename=')[1])// const fileName = newNameif ('download' in document.createElement('a')) {// 非IE下载const elink = document.createElement('a')elink.download = fileNameelink.style.display = 'none'elink.href = URL.createObjectURL(blob)document.body.appendChild(elink)elink.click()URL.revokeObjectURL(elink.href) // 释放URL 对象document.body.removeChild(elink)} else {// IE10+下载navigator.msSaveBlob(blob, fileName)}})
}

方法2,使用form表单下载

  /* 下载方案2 */let form = document.createElement('form')form.style.display = 'none'form.action = '/backend/emp/employee/export/empLabel'form.method = 'post'document.body.appendChild(form)for (let key in params) {let input = document.createElement('input')input.type = 'hidden'input.name = keyinput.value = params[key]form.appendChild(input)}form.submit()form.remove()

方法3,直接用a标签导出

/* 下载方案3 */

  if (selectRow.length === 0) {this.$message.error('请选择员工再导出员工标签')return false}let employeeIds = selectRow.map(item => item.employeeId).join(',')const el = document.createElement('a')document.body.appendChild(el)el.href = `/backend/emp/employee/export/empLabel/${employeeIds}/excelZip`el.click()document.body.removeChild(el)

更多推荐

JS下载或导出文件的三种方法

本文发布于:2024-03-10 11:18:21,感谢您对本站的认可!
本文链接:https://www.elefans.com/category/jswz/34/1727829.html
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系,我们将在24小时内删除。
本文标签:三种   文件   方法   JS

发布评论

评论列表 (有 0 条评论)
草根站长

>www.elefans.com

编程频道|电子爱好者 - 技术资讯及电子产品介绍!