vue解决excel文件下载问题

/**
 * @param {Object} url  请求地址
 * @param {Object} params  请求参数
 * @param {Object} fileName 文件完整名称,包括类型
 * @param {Object} httpType 返回的文件格式
 */
POSTFILE(url, params, fileName, httpType) {

   var AxiosRequestConfig = {
      responseType: "blob"
   }
   var data = axios.post(`${base}${url}`, params, AxiosRequestConfig).then((res) => {
      if (res.status == 200) {
         let blob = new Blob([res.data], {
            type: httpType
         })
         if (window.navigator.msSaveOrOpenBlob) {
            navigator.msSaveBlob(blob, fileName)
         } else {
            var link = document.createElement('a')
            link.href = window.URL.createObjectURL(blob)
            link.download = fileName
            link.click()
            //释放内存
            window.URL.revokeObjectURL(link.href)
         }

      } else
         Message.error("操作失败,服务端出现异常错误!")
   })
   return data;

},

你可能感兴趣的:(vue.js,javascript,ecmascript)