Vue實現(xiàn)導出Excel表格文件提示“文件已損壞無法打開”的解決方法
一、vue實現(xiàn)導出excel
1、前端實現(xiàn)
xlsx是一個用于讀取、解析和寫入Excel文件的JavaScript庫。它提供了一系列的API來處理Excel文件。使用該庫,你可以將數(shù)據(jù)轉(zhuǎn)換為Excel文件并下載到本地。這種方法適用于在前端直接生成Excel文件的場景。
安裝xlsx依賴
npm install xlsx --save
引入并使用
<template>
<div>
<button @click="exportExcel">導出excel</button>
</div>
</template>
<script>
import XLSX from 'xlsx'
export default {
methods: {
exportExcel() {
// 準備要導出的數(shù)據(jù)
const data = [
['姓名','年齡','性別','地址'],
['張三',18,'男','北京市'],
['李四',19,'女','上海市']
]
// 將數(shù)據(jù)轉(zhuǎn)換為工作簿對象
const ws = XLSX.utils.aoa_to_sheet(data)
const wb = XLSX.utils.book_new()
XLSX.utils.book_append_sheet(wb,ws,'Sheet1')
// 導出Excel文件
XLSX.writeFile(wb,'test.xlsx')
}
}
}
</script>2、后端實現(xiàn)
在這種方法中,前端發(fā)起一個請求到后端,后端生成Excel文件并返回給前端,前端再將文件下載到本地??梢允褂胊xios庫來發(fā)起請求,并使用Blob和a標簽來下載文件。這種方法適用于需要在后端處理數(shù)據(jù)并生成Excel文件的場景。
后端返回blob流文件,前端接收并導出。
<template>
<div>
<button @click="exportExcel">導出excel</button>
</div>
</template>
<script>
import axios from 'axios'
export default {
methods: {
exportToExcel() {
this.$http.get('/api/exportExcel').then(res => {
const blob = new Blob([res.data], {type: 'application/vnd.ms-excel'})
const link = document.createElement('a')
link.style.display = 'none'
link.href = URL.createObjectURL(blob)
link.download = 'test.xlsx'
document.body.appendChild(link)
link.click()
});
}
}
}
</script>二、導出文件損壞
前端開發(fā)中導出excel文件,文件可以正常下載,但是使用office或者wps
打開失敗,提示“文件已損壞,無法打開”。


1、前端請求導出接口,增加返回類型
注意,excel流文件一定要在請求的時候加上響應類型字段,也就是:responseType: 'blob’或者,responseType: ‘arraybuffer’ ,否則下載出來的excel文件就會損壞,就會打不開。
axios發(fā)請求,給axios做了二次封裝,在請求攔截器的地方添加。
// 引入axios
import axiosFile from "axios"
// 創(chuàng)建axios實例
const axiosExport = axiosFile.create()
// request攔截器
axiosExport.interceptors.request.use((req)=>{
//添加響應類型
req.responseType = "blob"
return req
})2、取消受保護的視圖
具體操作:打開excel文件,點擊頁面上方的左側(cè)“文件”,然后點擊“更多”里面的“選項”;在“信任中心”選擇“信任中心設置”;再點擊“受保護的視圖”,取消選擇右側(cè)面板里面的勾選,最后點擊“確定”。
點擊“選項”

點擊“信任中心”

點擊“受保護的視圖”

去掉右側(cè)的選項,點擊確定。
到此這篇關于Vue實現(xiàn)導出Excel表格,提示“文件已損壞,無法打開”的解決方法的文章就介紹到這了,更多相關Vue導出Excel表格提示文件已損壞,無法打開內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
vue+iview框架實現(xiàn)左側(cè)動態(tài)菜單功能的示例代碼
這篇文章主要介紹了vue+iview框架實現(xiàn)左側(cè)動態(tài)菜單功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-07-07
自帶氣泡提示的vue校驗插件(vue-verify-pop)
這篇文章主要為大家詳細介紹了自帶氣泡提示的vue校驗插件,vue-verify-pop的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04

