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

Angular Excel 導(dǎo)入與導(dǎo)出的實現(xiàn)代碼

 更新時間:2019年04月17日 15:13:52   作者:ValueMar  
這篇文章主要介紹了Angular Excel 導(dǎo)入與導(dǎo)出的實現(xiàn)代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧

前言

本文基于 angular v7.2.7,初次編寫于2019-4-17。

雖然代碼是基于angular 7.2.7,但是語法是基于 angular 4.X 以上均可使用 。在項目開發(fā)過程中,我們經(jīng)常需要跟后端進行文件交互,常見的諸如 圖片上傳,excel 導(dǎo)入與導(dǎo)出等。這里我們只討論關(guān)于excel 的導(dǎo)入與導(dǎo)出。

Excel 導(dǎo)入

excel 導(dǎo)入在angular 中其實非常簡單,只需要安裝 xlsx插件 就可以了。

安裝 xlsx 插件

npm install xlsx --save

在component 中導(dǎo)入

import * as XLSX from 'xlsx';

關(guān)鍵代碼

import * as XLSX from 'xlsx';

excelData = [];

importExcel(evt: any) {
  /* wire up file reader */
  const target: DataTransfer = <DataTransfer>(evt.target);
  if (target.files.length !== 1) throw new Error('Cannot use multiple files');
  const reader: FileReader = new FileReader();
  reader.onload = (e: any) => {
   /* read workbook */
   const bstr: string = e.target.result;
   const wb: XLSX.WorkBook = XLSX.read(bstr, { type: 'binary' });

   /* grab first sheet */
   const wsname: string = wb.SheetNames[0];
   const ws: XLSX.WorkSheet = wb.Sheets[wsname];

   /* save data */
   this.excelData = (XLSX.utils.sheet_to_json(ws, { header: 1 }));

   evt.target.value = "" // 清空
  };
  reader.readAsBinaryString(target.files[0]);

 }

Excel 導(dǎo)出

傳統(tǒng)的導(dǎo)出功能我們一般是放在后端實現(xiàn),由后端生成文件的Url或者文件流給到前端。注:這種是通過瀏覽器的下載功能直接下載的。一般有以下幾種方式實現(xiàn):

get 請求 + window.open(url)

后端返回一個 文件的url 或者 文件流,這種方式均可以直接下載。 前提是http請求為get 。

post 請求 + <a>標(biāo)簽

前端代碼:

exportExcel(codeList: string[]) {
  return this.http.post(this.ExportExcelByCodesUrl, codeList, {
   responseType: 'arraybuffer',//設(shè)置響應(yīng)類型
   observe:"response",//返回response header
   headers: { 'Content-Type': 'application/json' }
  })
   .subscribe((response:any)=>{
    this.downLoadFile(response, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;charset=utf-8")
   })

 }

 /**
  * Method is use to download file.
  * @param data - Array Buffer data
  * @param type - type of the document.
 */
downLoadFile(data: any, type: string) {
   var blob = new Blob([data.body], { type: type});
   let downloadElement = document.createElement('a');
   let href = window.URL.createObjectURL(blob); //創(chuàng)建下載的鏈接
   downloadElement.href = href;
   let filename = data.headers.get("Download-FileName");//后端返回的自定義header
   downloadElement.download = decodeURI(filename); 

   document.body.appendChild(downloadElement);
   downloadElement.click(); //點擊下載
   document.body.removeChild(downloadElement); //下載完成移除元素
   window.URL.revokeObjectURL(href); //釋放掉blob對象
 }

后端代碼:

這里后端是使用的Asp.Net Core 2.1

public IActionResult CreateExcel(string fileName,List<ExportProductModel> list)
 {
  string[] propertyNames = {""};//業(yè)務(wù)代碼
  string[] propertyNameCn = {""};//業(yè)務(wù)代碼
  MemoryStream ms = ExcelsHelper<ExportProductModel>.ListToExcel(fileName, list, propertyNames, propertyNameCn);
  HttpContext.Response.Headers.Add("Download-FileName",WebUtility.UrlEncode(fileName));
  return File(ms, "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet;", WebUtility.UrlEncode(fileName));
 }

services.AddCors(options =>
         {
          options.AddPolicy("AllowAllOrigin", builder =>
                   {
                    builder.AllowAnyHeader()
                     .AllowAnyMethod()
                     .AllowAnyOrigin()
                     .AllowCredentials()
                     .WithExposedHeaders("Download-FileName"); 

                   });
         });

后端代碼

這里關(guān)鍵點是需要設(shè)置跨域的響應(yīng)頭(也就是“Download-FileName”),具體每個語言有自己的實現(xiàn)方式。如果不設(shè)置的話,前端無法獲取響應(yīng)頭。

post 請求 + form 表單 + iframe 標(biāo)簽(暫無代碼實現(xiàn))

總結(jié)

我在開發(fā)過程中有遇到以下幾個問題,折騰了很久:

  • 前后端的MIME類型沒有對應(yīng),導(dǎo)致文件無法成功下載,這里是完整的MIME類型列表
  • 無法獲取response header,原因有二:

(1)后端沒有設(shè)置跨域的響應(yīng)頭

(2)前端的http請求 語法書寫錯誤,一直獲取到的是http response body,而非完整的http response。完整寫法參考以上代碼,關(guān)鍵是 : observe:"response"

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • AngularJS模塊管理問題的非常規(guī)處理方法

    AngularJS模塊管理問題的非常規(guī)處理方法

    這篇文章主要介紹了AngularJS模塊管理問題的非常規(guī)處理方法,算是一個無奈之舉,分享給小伙伴,大家可以參考下。
    2015-04-04
  • angular.extend方法的具體使用

    angular.extend方法的具體使用

    本篇文章主要介紹了angular.extend方法的具體使用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • AngularJS入門心得之directive和controller通信過程

    AngularJS入門心得之directive和controller通信過程

    Angular JS (Angular.JS) 是一組用來開發(fā)Web頁面的框架、模板以及數(shù)據(jù)綁定和豐富UI組件,接下來通過本文給大家介紹AngularJS入門心得之directive和controller通信過程,對angularjs相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • AngularJS中比較兩個數(shù)組是否相同

    AngularJS中比較兩個數(shù)組是否相同

    這篇文章主要介紹了AngularJS中比較兩個數(shù)組是否相同,介紹的非常詳細(xì),具有參考借鑒價值,感興趣的朋友一起看下吧
    2016-08-08
  • 淺談AngularJS中ng-class的使用方法

    淺談AngularJS中ng-class的使用方法

    下面小編就為大家?guī)硪黄獪\談AngularJS中ng-class的使用方法。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2016-11-11
  • AngularJS之依賴注入模擬實現(xiàn)

    AngularJS之依賴注入模擬實現(xiàn)

    這篇文章主要為大家詳細(xì)介紹了AngularJS依賴注入模擬實現(xiàn),感興趣的小伙伴們可以參考一下
    2016-08-08
  • Angular短信模板校驗代碼

    Angular短信模板校驗代碼

    這篇文章主要介紹了Angular短信模板校驗代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-09-09
  • angularJS Provider、factory、service詳解及實例代碼

    angularJS Provider、factory、service詳解及實例代碼

    這篇文章主要介紹了angularJS Provider詳解及實例代碼的相關(guān)資料,需要的朋友可以參考下
    2016-09-09
  • AngularJS ng-repeat數(shù)組有重復(fù)值的解決方法

    AngularJS ng-repeat數(shù)組有重復(fù)值的解決方法

    不知道大家是否遇到過這個問題,在當(dāng)Angular.JS ng-repeat數(shù)組中有重復(fù)項時,系統(tǒng)就會拋出異常,這是該怎么做?本文通過示例代碼介紹了詳細(xì)的解決方法,有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-10-10
  • AngularJS入門教程之ng-checked 指令詳解

    AngularJS入門教程之ng-checked 指令詳解

    本文主要講解AngularJS ng-checked 指令,在這整理ng-checked 指令的基礎(chǔ)知識,并附代碼實例,有需要的小伙伴可以參考下
    2016-08-08

最新評論