vue下载excel时,如果excel有多个sheet,打开失败

excel有多个sheet时,可以下载,但是打开时提示文件损坏,打不开;但是只有一个sheet时是可以下载和打开的

下面是有多个sheet的情况
image.png

下面是只有一个sheet的情况(可以打开)
image.png

下载的方式是这样的

//下载全局方法
Vue.prototype.$download = (res, type = "application/vnd.ms-excel") => {
    let fileNames = res.headers["content-disposition"];
    let blob = new Blob([res.data], { type: type });
    let fileName = "";
    if (fileNames.indexOf('"') > 0) {
        fileName = decodeURI(fileNames.match(/"(.*)"$/)[1]);
    } else {
        fileName = decodeURI(fileNames.match(/=(.*)$/)[1]);
    }
    if ("download" in document.createElement("a")) {
        // 非IE下载
        const elink = document.createElement("a");
        elink.download = fileName;
        elink.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);
    }
};   
阅读 1.1k
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题