校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > ajax實現excel報表導出

ajax實現excel報表導出

熱門標簽:銷售電銷機器人詐騙 外呼系統api對接 提高電話機器人接通率 廣西智能外呼系統多少錢 福建微碼電話機器人 平涼高德地圖標注商戶要收費嗎 大學校門地圖標注 地圖標注與公司業務關系 荊州智能電銷機器人

利用ajax實現excel報表導出【解決亂碼問題】,供大家參考,具體內容如下

背景

項目中遇到一個場景,要導出一個excel報表。由于需要token驗證,所以不能用a標簽;由于頁面復雜,所以不能使用表單提交。初步考慮前端使用ajax,后端返回流,定義指定的header。

第一版

主要代碼

前端

使用jquery的ajax

var queryParams = {"test":"xxx"};
var url = "xxx";
$.ajax({
 type : "POST", //提交方式
 url : url,//路徑
 contentType: "application/json",
 data: JSON.stringify(queryParams),
 beforeSend: function (request) {
  request.setRequestHeader("Authorization", "xxx");
 },
 success : function(result) {
  const blob = new Blob([result], {type:"application/vnd.ms-excel"});
  if(blob.size  1) {
   alert('導出失敗,導出的內容為空!');
   return
  }
  if(window.navigator.msSaveOrOpenBlob) {
   navigator.msSaveOrOpenBlob(blob, 'test.xls')
  } else {
   const aLink = document.createElement('a');
   aLink.style.display = 'none';
   aLink.href = window.URL.createObjectURL(blob);
   aLink.download = 'test.xls';
   document.body.appendChild(aLink);
   aLink.click();
   document.body.removeChild(aLink);
  }
 }
});

后端

使用easypoi(如何使用easypoi請自行百度)

import cn.afterturn.easypoi.excel.ExcelExportUtil;
import cn.afterturn.easypoi.excel.entity.ExportParams;

@PostMapping(value = "/download")
public void downloadList(@RequestBody Objct obj, HttpServletResponse response) {

 ......

 ListCustom> excelList = new ArrayList>();
 
   // excel總體設置
   ExportParams exportParams = new ExportParams();
   // 指定sheet名字
   exportParams.setSheetName("test");
   Workbook workbook = ExcelExportUtil.exportExcel(exportParams, Custom.class, excelList);
 
   response.setContentType("application/vnd.ms-excel");
   response.addHeader("Content-Disposition", "attachment;filename=" + URLEncoder.encode("test", "utf-8") + ".xls");
   OutputStream outputStream = response.getOutputStream();
   workbook.write(outputStream);
   outputStream.flush();
   outputStream.close();
   
 ......
 
}

測試結果

excel能正常導出,但下載下來的excel全是亂碼。經過各種找答案,整理了一下可能是以下原因導致:

1、后端未設置字符集,或者在spring框架的過濾器中統一設置了字符集;
2、前端頁面未設置字符集編碼;
3、需要在ajax中添加 request.responseType = “arraybuffer”;

經過不斷測試,我的應該是第三點導致。但在jquery ajax 中添加后仍然不起作用,亂碼問題始終無法解決。

第二版

主要代碼

前端,使用原生的ajax。后端未變動。

var xhr = new XMLHttpRequest();
xhr.responseType = "arraybuffer"; 
xhr.open("POST", url, true);
xhr.onload = function () {
 const blob = new Blob([this.response], {type:"application/vnd.ms-excel"});
 if(blob.size  1) {
  alert('導出失敗,導出的內容為空!');
  return;
 }
 if(window.navigator.msSaveOrOpenBlob) {
  navigator.msSaveOrOpenBlob(blob, 'test.xls')
 } else {
  const aLink = document.createElement('a');
  aLink.style.display = 'none';
  aLink.href = window.URL.createObjectURL(blob);
  aLink.download = 'testxls';
  document.body.appendChild(aLink);
  aLink.click();
  document.body.removeChild(aLink);
  return;
 }
}
xhr.setRequestHeader("Authorization", "xxx");
xhr.setRequestHeader("Content-Type", "application/json");
xhr.send(JSON.stringify(queryParams));

測試結果

下載的excel不再亂碼,原生ajax中使用 “arraybuffer” 使用是生效的。

總結

“arraybuffer” 這個參數導致的excel導出亂碼,在原生的ajax中設置是有效的,在jquery的ajax中暫時還沒找到生效的方式。

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

您可能感興趣的文章:
  • PHP使用ajax的post方式下載excel文件簡單示例
  • 使用Ajax生成的Excel文件并下載的實例
  • 原生JS封裝ajax 傳json,str,excel文件上傳提交表單(推薦)
  • Jquery ajax請求導出Excel表格的實現代碼
  • AJAX 仿EXCEL表格功能

標簽:樂山 內江 衡陽 海南 邯鄲 黔東 婁底 德陽

巨人網絡通訊聲明:本文標題《ajax實現excel報表導出》,本文關鍵詞  ajax,實現,excel,報表,導出,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《ajax實現excel報表導出》相關的同類信息!
  • 本頁收集關于ajax實現excel報表導出的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    亚洲天堂av一区| 91精品国产综合久久福利软件| 精品久久久久久亚洲综合网| 蜜臀av在线播放一区二区三区| 欧美国产欧美亚州国产日韩mv天天看完整 | 人人狠狠综合久久亚洲| 亚洲欧美一区二区视频| 91精品免费在线| 成人动漫视频在线| 成人午夜视频在线观看| 国产麻豆精品一区二区| 麻豆91免费观看| 日韩精品亚洲一区二区三区免费| 91精品视频网| 粉嫩aⅴ一区二区三区四区 | 免费的国产精品| 午夜在线成人av| 亚洲成人动漫一区| 亚洲.国产.中文慕字在线| 亚洲第一福利一区| 亚洲激情六月丁香| 一区二区三区欧美亚洲| 亚洲免费av网站| 亚洲男人的天堂在线aⅴ视频| 精品国产一区二区三区av性色| 欧美一区二区三区精品| 日韩免费看的电影| 久久久久久久久久久电影| 久久精品网站免费观看| 国产欧美久久久精品影院| 51久久夜色精品国产麻豆| 欧美精品一级二级三级| 欧美一级欧美三级| 久久色在线观看| 国产精品久久久久久妇女6080| 欧美电影免费观看完整版| wwwwxxxxx欧美| 国产精品私人影院| 久久免费视频一区| 欧美国产日产图区| 一二三四区精品视频| 五月婷婷欧美视频| 国产一区二区三区在线看麻豆| 成人精品一区二区三区四区 | 色综合久久九月婷婷色综合| 欧美精品久久久久久久多人混战 | 国产精品二区一区二区aⅴ污介绍| 一级中文字幕一区二区| 日韩va欧美va亚洲va久久| 青青草国产成人av片免费| 国产1区2区3区精品美女| 成人黄色在线网站| 色综合久久中文综合久久牛| 欧美一区二区视频网站| 国产精品传媒入口麻豆| 夜夜揉揉日日人人青青一国产精品| 日韩av一区二区三区| 成人黄色av网站在线| 制服.丝袜.亚洲.中文.综合| 国产精品免费丝袜| 综合婷婷亚洲小说| 麻豆视频观看网址久久| 黄页网站大全一区二区| 在线日韩国产精品| 日韩一本二本av| 成人免费在线视频| 国产一区二区三区四区在线观看| 在线精品观看国产| 国产精品久久久久久久久免费丝袜| 亚洲天堂a在线| 日本vs亚洲vs韩国一区三区二区| av电影一区二区| 日韩精品一区二区三区swag| 无码av免费一区二区三区试看| 激情小说亚洲一区| 91丝袜美女网| 久久久久久久久伊人| 久久精品国产**网站演员| a在线播放不卡| 精品少妇一区二区三区在线播放 | 懂色一区二区三区免费观看 | 亚洲国产wwwccc36天堂| 午夜国产精品一区| 欧美日韩亚洲不卡| 久久97超碰国产精品超碰| 欧美变态口味重另类| 国产一区二区三区四| 国产精品欧美综合在线| 99久久精品免费精品国产| 综合激情网...| 欧美亚州韩日在线看免费版国语版| 亚洲男女一区二区三区| 欧美日韩精品专区| 精品在线免费观看| 一区在线中文字幕| 一本久久a久久精品亚洲| 中文字幕av一区二区三区高| 国产精品一区二区在线播放| 国产亚洲污的网站| 高清不卡一二三区| 欧美一区二视频| 捆绑调教美女网站视频一区| 久久午夜羞羞影院免费观看| 国产精品一级在线| 亚洲国产精华液网站w| www..com久久爱| 亚洲不卡在线观看| 久久先锋资源网| 色94色欧美sute亚洲线路一ni| 亚洲成av人片在线观看| 久久久久国色av免费看影院| 色哟哟国产精品免费观看| 精品写真视频在线观看| 依依成人综合视频| 久久麻豆一区二区| 欧美精品视频www在线观看| 粉嫩av一区二区三区在线播放 | 国产精品国产三级国产aⅴ中文| 大桥未久av一区二区三区中文| 亚洲一二三四区不卡| 69堂国产成人免费视频| 国产999精品久久| 一区二区三区四区在线| 日韩欧美高清一区| 91天堂素人约啪| 久久精品国产精品亚洲精品| 亚洲人123区| 精品蜜桃在线看| 欧美日本韩国一区二区三区视频| 国产成人在线视频网址| 亚洲国产日日夜夜| 久久精子c满五个校花| 欧美日韩一区在线| 国产成人精品免费视频网站| 亚洲高清免费观看| 中文一区一区三区高中清不卡| 色综合 综合色| 国产精品911| 日韩av一级片| 亚洲综合免费观看高清完整版在线| 欧美精品一区二区久久婷婷 | 亚洲精选视频在线| 精品国产91久久久久久久妲己| 精品视频在线免费观看| 波多野结衣亚洲一区| 韩国理伦片一区二区三区在线播放| 亚洲一区二区三区自拍| 国产欧美一区二区精品婷婷 | 欧美日韩一区二区三区视频| 白白色亚洲国产精品| 国产成人av网站| 国产91对白在线观看九色| 久88久久88久久久| 天天色 色综合| 亚洲国产精品人人做人人爽| 国产精品不卡一区| 久久精品免视看| 精品国产污污免费网站入口| 在线观看免费成人| 成人在线视频首页| 成人一区二区视频| 国产一区久久久| 久久激情五月激情| 久久久久99精品国产片| 精品入口麻豆88视频| 久久久久久影视| 中文字幕中文在线不卡住| 国产精品久久福利| 夜夜操天天操亚洲| 亚洲一区二区三区在线播放| 美腿丝袜在线亚洲一区| 国产精品影视网| 99久久99久久综合| 欧美日韩在线三级| 久久青草国产手机看片福利盒子 | 国产精品女人毛片| 一区二区三区高清| 免费人成在线不卡| 福利视频网站一区二区三区| 色哟哟欧美精品| 亚洲欧洲制服丝袜| 丁香网亚洲国际| 成熟亚洲日本毛茸茸凸凹| 91性感美女视频| 欧美日韩的一区二区| 欧美精品一区二区高清在线观看 | 国产精品亚洲人在线观看| 不卡区在线中文字幕| 欧美日韩国产乱码电影| 久久精品欧美日韩精品| 亚洲一区二区av在线| 国产精一区二区三区| 欧美视频一二三区| 欧美高清在线一区二区| 一区二区三区91| 国产sm精品调教视频网站| 欧美区视频在线观看| 国产精品久久久久天堂| 美美哒免费高清在线观看视频一区二区| 国产99一区视频免费|