download.ts 1.1 KB

1234567891011121314151617181920212223242526272829303132
  1. import download from 'downloadjs';
  2. import { ElMessage } from 'element-plus';
  3. const downloadFile = (res: any, fileName: string = '导出日志.xlsx') => {
  4. // 判断是不是返回的是json,是json说明报错了,否则返回的是文本流
  5. const decoder = new TextDecoder('utf-8');
  6. const text = decoder.decode(res.data);
  7. // console.log(text)
  8. try {
  9. const errJson = JSON.parse(text)
  10. if (errJson.message) {
  11. ElMessage.closeAll()
  12. ElMessage.error(errJson.message)
  13. } else {
  14. // 可能是导出 json文件
  15. beginDownload(res, fileName)
  16. }
  17. } catch {
  18. beginDownload(res, fileName)
  19. }
  20. }
  21. function beginDownload(res: any, fileName: string) {
  22. // 用split是避免多次取值重复都好分割的情况,比如
  23. // attachment; filename="2022-12-06 21:34:35-SysLoginLog.xlsx", attachment; filename="2022-12-06 21:34:35-SysLoginLog.xlsx"
  24. const lastFileName = res.headers['content-disposition'] ? res.headers['content-disposition'].split(',')[0].replaceAll('attachment; filename="', '').replaceAll('"', '') : fileName;
  25. download(res.data, lastFileName, res.headers['content-type']);
  26. }
  27. export default downloadFile