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

Angular利用HTTP POST下載流文件的步驟記錄

 更新時(shí)間:2020年07月26日 10:43:39   作者:Guoye  
這篇文章主要給大家介紹了關(guān)于Angular利用HTTP POST下載流文件的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者使用Angular具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧

Angular / Vue HTTP POST下載流文件

HTTP POST 請求流文件轉(zhuǎn)成excel

在使用Angular開發(fā)項(xiàng)目時(shí),通常會(huì)有下載文件的功能項(xiàng)。一般是后臺(tái)返回下載地址,通過 <a> 標(biāo)題或者使用 window 打開下載地址新窗口,瀏覽器則會(huì)識(shí)別出流文件進(jìn)行文件下載。

但是,有時(shí)候進(jìn)行http異步請求,后臺(tái)返回的并不是下載地址,而是直接返回一個(gè)文件流,這時(shí)如何使用http請求回來的文件流轉(zhuǎn)換成文件下載?

其實(shí)并非Angular框架存地這樣的情況,其他PWA如Vue,React甚至Jquery都通過http xhr進(jìn)行請求而獲取的流文件,瀏覽器也并不會(huì)自動(dòng)識(shí)別并自動(dòng)下載。

那當(dāng)然,肯定有解決方案。

方案思路:

http請求使用blob的返回類型,獲取文件流后,對數(shù)據(jù)進(jìn)行Blob,再提交給瀏覽器進(jìn)行識(shí)

下面是代碼示例

/**
 * 導(dǎo)出excel
 */
exportExcel(){
 const params = {}; // body的參數(shù)
 const queryParams = undefined; // url query的參數(shù)
 this.http.post(this.exportUrl, params, queryParams, {
 responseType: "blob",
 headers: new HttpHeaders().append("Content-Type", "application/json")
 }).subscribe(resp=>{
 // resp: 文件流
 this.downloadFile(resp);
 })
}

/**
 * 創(chuàng)建blob對象,并利用瀏覽器打開url進(jìn)行下載
 * @param data 文件流數(shù)據(jù)
 */
downloadFile(data) {
 // 下載類型 xls
 const contentType = 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet';
 // 下載類型:csv
 const contentType2 = 'text/csv';
 const blob = new Blob([data], { type: contentType });
 const url = window.URL.createObjectURL(blob);
 // 打開新窗口方式進(jìn)行下載
 // window.open(url); 

 // 以動(dòng)態(tài)創(chuàng)建a標(biāo)簽進(jìn)行下載
 const a = document.createElement('a');
 const fileName = this.datePipe.transform(new Date(), 'yyyyMMdd');
 a.href = url;
 // a.download = fileName;
 a.download = fileName + '.xlsx';
 a.click();
 window.URL.revokeObjectURL(url);
}

總結(jié)

到此這篇關(guān)于Angular利用HTTP POST下載流文件的文章就介紹到這了,更多相關(guān)Angular用HTTP POST下載流文件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 詳解AngularJS中的作用域

    詳解AngularJS中的作用域

    這篇文章主要介紹了詳解AngularJS中的作用域,是AngularJS學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-06-06
  • angular6.x中ngTemplateOutlet指令的使用示例

    angular6.x中ngTemplateOutlet指令的使用示例

    本篇文章主要介紹了angular6.x中ngTemplateOutlet指令的使用示例,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • 淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容

    淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容

    本篇文章主要介紹了淺談Angular2 ng-content 指令在組件中嵌入內(nèi)容,具有一定的參考價(jià)值,有興趣的可以了解一下
    2017-08-08
  • angular4實(shí)現(xiàn)帶搜索的下拉框

    angular4實(shí)現(xiàn)帶搜索的下拉框

    這篇文章主要為大家詳細(xì)介紹了angular4實(shí)現(xiàn)帶搜索的下拉框,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • Angular4學(xué)習(xí)教程之DOM屬性綁定詳解

    Angular4學(xué)習(xí)教程之DOM屬性綁定詳解

    這篇文章主要給大家介紹了關(guān)于Angular4學(xué)習(xí)教程之DOM屬性綁定的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。
    2018-01-01
  • 利用VS Code開發(fā)你的第一個(gè)AngularJS 2應(yīng)用程序

    利用VS Code開發(fā)你的第一個(gè)AngularJS 2應(yīng)用程序

    這篇文章主要給大家介紹了關(guān)于利用VS Code如何開發(fā)你的第一個(gè)AngularJS 2應(yīng)用程序的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友下面來一起看看吧。
    2017-12-12
  • 詳解angularjs中如何實(shí)現(xiàn)控制器和指令之間交互

    詳解angularjs中如何實(shí)現(xiàn)控制器和指令之間交互

    本篇文章主要介紹了詳解angularjs中如何實(shí)現(xiàn)控制器和指令之間交互,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-05-05
  • AngularJS基礎(chǔ) ng-mouseover 指令簡單示例

    AngularJS基礎(chǔ) ng-mouseover 指令簡單示例

    本文主要介紹AngularJS ng-mouseover 指令,這里幫大家整理了AngularJS 指令的基礎(chǔ)知識(shí),并附代碼示例,有興趣的小伙伴可以參考下
    2016-08-08
  • Angularjs編寫KindEditor,UEidtor,jQuery指令

    Angularjs編寫KindEditor,UEidtor,jQuery指令

    使用過 AngularJS 的朋友應(yīng)該最感興趣的是它的指令?,F(xiàn)今市場上的前端框架也只有AngularJS 擁有自定義指令的功能,并且AngularJS 是目前唯一提供Web應(yīng)用可復(fù)用能力的框架。
    2015-01-01
  • 手動(dòng)初始化Angular的模塊與控制器

    手動(dòng)初始化Angular的模塊與控制器

    本文主要介紹了手動(dòng)初始化Angular的模塊與控制器的方法,具有一定的參考價(jià)值,下面跟著小編一起來看下吧
    2016-12-12

最新評論