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

vue導(dǎo)出excel文件流中文亂碼問題及解決

 更新時間:2022年06月02日 11:30:21   作者:Thekingyu  
這篇文章主要介紹了vue導(dǎo)出excel文件流中文亂碼問題及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

導(dǎo)出excel文件流中文亂碼

解決此方法很多網(wǎng)上的差不多都可以。一下提供簡單的方法

 loads(){
		  let data={
			  userWord:this.dataList.userWord,
			  examId:this.$route.query.id,
			  exportType:this.active,
		  }
		api.exportUserResult(data).then((res) => {
					const blob = new Blob([res.data]); 
                    const fileName = '考試成績.xls';
                    const linkNode = document.createElement('a');
                    linkNode.download = fileName; //a標(biāo)簽的download屬性規(guī)定下載文件的名稱
                    linkNode.style.display = 'none';
                    linkNode.href = URL.createObjectURL(blob); //生成一個Blob URL
                    document.body.appendChild(linkNode);
                    linkNode.click();  //模擬在按鈕上的一次鼠標(biāo)單擊
                    URL.revokeObjectURL(linkNode.href); // 釋放URL 對象
                    document.body.removeChild(linkNode);
      });
	  },

注意:

填寫

另住攔截器,因為判斷result,沒在正確里返回,所以我直接返回

導(dǎo)出excel亂碼(錕斤拷唷?錕?;錕斤拷)

我這個是 post請求亂碼了 ,如果是get,就直接window.open(url,'_blank')就可以了

1.“錕斤拷唷?錕?;錕斤拷”這種亂碼信息導(dǎo)致的原因是:整個數(shù)據(jù)流的字符集 GBK=>UTF-8=>GBK導(dǎo)致的。

2. 前端代碼:

     axios({
        method: "post",
        url: url,
        data: params,
        headers: {
          // ... 接口需要的請求頭
        },
        responseType: "blob"
      }).then(response => {
        const blob =  new Blob([res.data],{type: 'application/vnd.ms-excel'});
        const fileName = res.headers["content-disposition"].split("=")[1]; //接口響應(yīng)頭定義的文件名
        downloadFile(blob, fileName);
      });
//import { Message } from "element-ui";
 
/**
 * 文件下載, 對于下載鏈接可直接用 window.open(url, "_blank");
 * @param {*} data 二進制數(shù)據(jù)或base64編碼 Blob、String
 * @param {*} fileName 下載的文件命名,可帶擴展名,跨域下無效
 */
export function downloadFile(data, fileName) {
  let url = "";
  let isBlob = false;
  const errMsg = "下載出錯,文件數(shù)據(jù)無法識別!";
 
  if (data instanceof Blob) {
    isBlob = true;
    url = window.URL.createObjectURL(data);
  } else if (typeof data == "string") {
    // base64編碼
    url = data;
  } else {
    Message.error(errMsg);
    return;
  }
 
  if ("download" in document.createElement("a")) {
    // 非IE下載
    const tmpLink = document.createElement("a");
    tmpLink.download = fileName || "";
    tmpLink.style.display = "none";
    tmpLink.href = url;
    document.body.appendChild(tmpLink);
    tmpLink.click();
    window.URL.revokeObjectURL(tmpLink.href); // 釋放URL 對象
    document.body.removeChild(tmpLink);
  } else {
    // IE10+下載
    if (isBlob) {
      window.navigator.msSaveBlob(data, fileName);
    } else {
      //Message.error(errMsg);
      console.log(errMsg);
      return;
    }
  }
}

3. 感覺完美 但是結(jié)果下載下來的如一開始截圖的亂碼,其實代碼沒有問題,問題在于前端項目啟用了mock.js,把所有 import 或 require   @/mock  的地方注釋調(diào)就可以了

以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • 如何在在Vue3中使用markdown 編輯器組件

    如何在在Vue3中使用markdown 編輯器組件

    vue3發(fā)布正式版不久,生態(tài)還沒完全發(fā)展起來,目前支持vue3的開源markdown編輯器組件基本上也寥寥無幾,向大家推薦一個很好用的v-md-editor 組件,組件功能很強大,文檔也比較詳細(xì)。該文章只介紹組件的常用功能,更多高級的功能可以參考官方文檔。
    2021-05-05
  • Vue中TypeScript和Pinia使用方法

    Vue中TypeScript和Pinia使用方法

    這篇文章主要介紹了Vue中TypeScript和Pinia使用方法,讓我們來看一個簡單的示例來演示TypeScript 和 Pinia的強大之處,需要的朋友可以參考下
    2023-07-07
  • vue使用element-ui按需引入時踩過的那些坑

    vue使用element-ui按需引入時踩過的那些坑

    Element-UI是基于vue實現(xiàn)的一套不依賴業(yè)務(wù)的UI組件庫,提供了豐富的PC端組件,減少用戶對常用組件的封裝,降低了開發(fā)的難易程度,下面這篇文章主要給大家介紹了關(guān)于vue使用element-ui按需引入時踩過的那些坑,需要的朋友可以參考下
    2022-05-05
  • npm?run?dev失敗的簡單解決辦法

    npm?run?dev失敗的簡單解決辦法

    最近工作中遇到了npm?run?dev報錯這個問題,通過查找相關(guān)資料最終解決了,所以下面這篇文章主要給大家介紹了關(guān)于npm?run?dev失敗的詳細(xì)解決辦法,文中通過實例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2022-07-07
  • vue3?中使用?jsx?開發(fā)的詳細(xì)過程

    vue3?中使用?jsx?開發(fā)的詳細(xì)過程

    這篇文章主要介紹了vue3?中使用?jsx?開發(fā),本文著重說一下在使用 .vue 文件和 .jsx 文件在使用語法上的差異,需要的朋友可以參考下
    2022-09-09
  • Vue.js如何利用v-for循環(huán)生成動態(tài)標(biāo)簽

    Vue.js如何利用v-for循環(huán)生成動態(tài)標(biāo)簽

    這篇文章主要給大家介紹了關(guān)于Vue.js如何利用v-for循環(huán)生成動態(tài)標(biāo)簽的相關(guān)資料,文中通過實例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2022-01-01
  • Vue子組件與父組件詳細(xì)解析

    Vue子組件與父組件詳細(xì)解析

    這篇文章主要介紹的是Vue子組件與父組件,什么是父組件,什么是子組件很多時候面對這個問題我們都會有所混淆,下面文章我們就來詳細(xì)介紹,需要的朋友可以參考一下
    2021-10-10
  • vue生命周期四個階段created和mount詳解

    vue生命周期四個階段created和mount詳解

    這篇文章主要介紹了vue生命周期四個階段created和mount,本文給大家介紹的非常詳細(xì),補充介紹了什么是實例,什么是實例被掛載到DOM,什么是dom,dao操作又是什么,感興趣的朋友跟隨小編一起看看吧
    2024-02-02
  • vue實現(xiàn)右側(cè)滑出層動畫

    vue實現(xiàn)右側(cè)滑出層動畫

    這篇文章主要為大家詳細(xì)介紹了vue實現(xiàn)右側(cè)滑出層動畫,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-04-04
  • 詳解Vue的數(shù)據(jù)及事件綁定和filter過濾器

    詳解Vue的數(shù)據(jù)及事件綁定和filter過濾器

    這篇文章主要為大家介紹了Vue的數(shù)據(jù)及事件綁定和filter過濾器,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-01-01

最新評論