欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Vue實(shí)現(xiàn)導(dǎo)出Excel表格文件提示“文件已損壞無(wú)法打開(kāi)”的解決方法

 更新時(shí)間:2024年01月04日 11:30:30   作者:鄒榮樂(lè)  
xlsx用于讀取解析和寫(xiě)入Excel文件的JavaScript庫(kù),它提供了一系列的API處理Excel文件,使用該庫(kù),可以將數(shù)據(jù)轉(zhuǎn)換Excel文件并下載到本地,適用于在前端直接生成Excel文件,這篇文章主要介紹了Vue實(shí)現(xiàn)導(dǎo)出Excel表格,提示文件已損壞,無(wú)法打開(kāi)的解決方法,需要的朋友可以參考下

一、vue實(shí)現(xiàn)導(dǎo)出excel

1、前端實(shí)現(xiàn)

xlsx是一個(gè)用于讀取、解析和寫(xiě)入Excel文件的JavaScript庫(kù)。它提供了一系列的API來(lái)處理Excel文件。使用該庫(kù),你可以將數(shù)據(jù)轉(zhuǎn)換為Excel文件并下載到本地。這種方法適用于在前端直接生成Excel文件的場(chǎng)景。

安裝xlsx依賴

npm install xlsx --save

引入并使用

<template>
    <div>
        <button @click="exportExcel">導(dǎo)出excel</button>
    </div>
</template>
<script>
import XLSX from 'xlsx'
export default {
    methods: {
        exportExcel() {
            // 準(zhǔn)備要導(dǎo)出的數(shù)據(jù)  
            const data = [
                ['姓名','年齡','性別','地址'],
                ['張三',18,'男','北京市'],
                ['李四',19,'女','上海市']
            ]
            // 將數(shù)據(jù)轉(zhuǎn)換為工作簿對(duì)象 
            const ws = XLSX.utils.aoa_to_sheet(data)
            const wb = XLSX.utils.book_new()
            XLSX.utils.book_append_sheet(wb,ws,'Sheet1')
            // 導(dǎo)出Excel文件  
            XLSX.writeFile(wb,'test.xlsx')
        }
    }
}
</script>

2、后端實(shí)現(xiàn)

在這種方法中,前端發(fā)起一個(gè)請(qǐng)求到后端,后端生成Excel文件并返回給前端,前端再將文件下載到本地??梢允褂胊xios庫(kù)來(lái)發(fā)起請(qǐng)求,并使用Blob和a標(biāo)簽來(lái)下載文件。這種方法適用于需要在后端處理數(shù)據(jù)并生成Excel文件的場(chǎng)景。

后端返回blob流文件,前端接收并導(dǎo)出。

<template>
    <div>
        <button @click="exportExcel">導(dǎo)出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>

二、導(dǎo)出文件損壞

前端開(kāi)發(fā)中導(dǎo)出excel文件,文件可以正常下載,但是使用office或者wps
打開(kāi)失敗,提示“文件已損壞,無(wú)法打開(kāi)”。

1、前端請(qǐng)求導(dǎo)出接口,增加返回類(lèi)型

注意,excel流文件一定要在請(qǐng)求的時(shí)候加上響應(yīng)類(lèi)型字段,也就是:responseType: 'blob’或者,responseType: ‘arraybuffer’ ,否則下載出來(lái)的excel文件就會(huì)損壞,就會(huì)打不開(kāi)。

axios發(fā)請(qǐng)求,給axios做了二次封裝,在請(qǐng)求攔截器的地方添加。

// 引入axios
import axiosFile from "axios"
// 創(chuàng)建axios實(shí)例
const axiosExport = axiosFile.create()
// request攔截器
axiosExport.interceptors.request.use((req)=>{
    //添加響應(yīng)類(lèi)型
    req.responseType = "blob"
    return req
})

2、取消受保護(hù)的視圖

具體操作:打開(kāi)excel文件,點(diǎn)擊頁(yè)面上方的左側(cè)“文件”,然后點(diǎn)擊“更多”里面的“選項(xiàng)”;在“信任中心”選擇“信任中心設(shè)置”;再點(diǎn)擊“受保護(hù)的視圖”,取消選擇右側(cè)面板里面的勾選,最后點(diǎn)擊“確定”。

點(diǎn)擊“選項(xiàng)”

點(diǎn)擊“信任中心”

點(diǎn)擊“受保護(hù)的視圖”

去掉右側(cè)的選項(xiàng),點(diǎn)擊確定。

到此這篇關(guān)于Vue實(shí)現(xiàn)導(dǎo)出Excel表格,提示“文件已損壞,無(wú)法打開(kāi)”的解決方法的文章就介紹到這了,更多相關(guān)Vue導(dǎo)出Excel表格提示文件已損壞,無(wú)法打開(kāi)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vue攔截器如何增加token參數(shù)

    vue攔截器如何增加token參數(shù)

    這篇文章主要介紹了vue攔截器如何增加token參數(shù)問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vue3實(shí)現(xiàn)跨標(biāo)簽頁(yè)通信的四種方式

    Vue3實(shí)現(xiàn)跨標(biāo)簽頁(yè)通信的四種方式

    在Vue應(yīng)用中,跨標(biāo)簽頁(yè)的通信通常涉及到兩個(gè)或多個(gè)瀏覽器標(biāo)簽頁(yè)之間的信息共享,由于每個(gè)標(biāo)簽頁(yè)或窗口都是獨(dú)立的JavaScript執(zhí)行環(huán)境,它們不能直接通過(guò)Vue或其他JavaScript庫(kù)來(lái)直接相互通信,但是,有一些方法可以實(shí)現(xiàn)這種跨標(biāo)簽頁(yè)的通信,以下是一些常用的跨標(biāo)簽頁(yè)通信方法
    2025-03-03
  • vue+iview框架實(shí)現(xiàn)左側(cè)動(dòng)態(tài)菜單功能的示例代碼

    vue+iview框架實(shí)現(xiàn)左側(cè)動(dòng)態(tài)菜單功能的示例代碼

    這篇文章主要介紹了vue+iview框架實(shí)現(xiàn)左側(cè)動(dòng)態(tài)菜單功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • vue組件jsx語(yǔ)法的具體使用

    vue組件jsx語(yǔ)法的具體使用

    本篇文章主要介紹了vue組件jsx語(yǔ)法的具體使用,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-05-05
  • Vue全局事件總線$bus安裝與應(yīng)用小結(jié)

    Vue全局事件總線$bus安裝與應(yīng)用小結(jié)

    這篇文章主要介紹了Vue全局事件總線$bus安裝與應(yīng)用,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-09-09
  • 記一次微信小程序與webviewH5通信的踩坑記錄

    記一次微信小程序與webviewH5通信的踩坑記錄

    uniapp開(kāi)發(fā)小程序的過(guò)程中主、分包有大小限制,隨著業(yè)務(wù)的增加,使用web-view加載H5的方式,往往純加載并不能滿足業(yè)務(wù)需求,這個(gè)時(shí)候就得了解小程序與H5的交互,這篇文章主要給大家介紹了關(guān)于微信小程序與webviewH5通信的踩坑記錄,需要的朋友可以參考下
    2024-07-07
  • 自帶氣泡提示的vue校驗(yàn)插件(vue-verify-pop)

    自帶氣泡提示的vue校驗(yàn)插件(vue-verify-pop)

    這篇文章主要為大家詳細(xì)介紹了自帶氣泡提示的vue校驗(yàn)插件,vue-verify-pop的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04
  • el-upload前端實(shí)現(xiàn)多文件上傳功能示例

    el-upload前端實(shí)現(xiàn)多文件上傳功能示例

    在Vue.js中可以使用Element UI庫(kù)中的<el-upload>組件來(lái)實(shí)現(xiàn)多文件上傳的功能,這篇文章主要給大家介紹了關(guān)于el-upload前端實(shí)現(xiàn)多文件上傳功能的相關(guān)資料,需要的朋友可以參考下
    2024-07-07
  • 如何解決ElementPlus的el-table底白線問(wèn)題

    如何解決ElementPlus的el-table底白線問(wèn)題

    這篇文章主要介紹了如何解決ElementPlus的el-table底白線問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-12-12
  • 通過(guò)命令行創(chuàng)建vue項(xiàng)目的方法

    通過(guò)命令行創(chuàng)建vue項(xiàng)目的方法

    這篇文章主要介紹了通過(guò)命令創(chuàng)建vue項(xiàng)目的方法,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-07-07

最新評(píng)論