vue前台导出zip文件_vue 导出excel/下载zip

本文介绍了在Vue.js应用中如何实现Excel文件的导出,针对后台返回的JSON格式和二进制数据流两种情况提供了详细的代码示例。通过调用axios库,结合Blob对象和FileReader API,实现了在浏览器端直接下载Excel文件的功能。
摘要由CSDN通过智能技术生成

vue 导出excel

1、如果后台数据是json格式的话就用如下方法:

exports() {

//导出

var url = " ";

this.$axios

._axios({

url: url,

method: "get"

// responseType: "blob",

})

.then(res => {

console.log(res);

this.$exportExcel(res.data, "商品信息");

})

.catch(err => {

console.log(err);

});

},

$exportExcel(data, name) {

console.log(data);

console.log(name);

let blob = new Blob([data], {

type: "application/vnd.ms-excel"

});

let url = window.URL.createObjectURL(blob);

let a = document.createElement("a");

a.href = url;

a.download = name + ".xlsx";

a.click();

window.URL.revokeObjectURL(url);

},

2、如果后台数据是二进制数据流就用如下方法:

exportsn() {

//导出

var url = " ";

let searchlist = {

search: {

is_del: this.formSearch.search.is_del,

category_id: this.formSearch.search.category_id,

content: this.formSearch.search.content,

type: this.formSearch.search.type,

brand_id: this.formSearch.search.brand_id

},

id: this.formShelves.id

};

this.$axios

.axiose({

url: url,

data: qs.stringify(searchlist),

method: "post",

responseType: "blob"

})

.then(result => {

if (window.navigator.msSaveOrOpenBlob) { //兼容ie 浏览器

let fileName = "商品清单" + ".xlsx";

navigator.msSaveBlob(result, fileName);

} else {

const blob = result;

const reader = new FileReader();

reader.readAsDataURL(blob);

reader.onload = e => {

const a = document.createElement("a");

a.download = `商品清单.xlsx`;

a.href = e.target.result;

document.body.appendChild(a);

a.click();

document.body.removeChild(a);

};

}

})

.catch(err => {

console.log(err);

});

},

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值