Ant Design Pro 下實現(xiàn)文件下載的實現(xiàn)代碼
最近編寫在頁面內(nèi)通過 AJAX 請求服務(wù)器下載文件遇到一些問題,網(wǎng)上找的資料和介紹大多不健全不系統(tǒng),最終自己摸索出來的解決方案,先簡單寫個初稿,后面再詳細(xì)補充。
表一:前端請求后端下載文件的各種情況
| 請求方法 | 請求方式 | 響應(yīng)結(jié)果 |
|---|---|---|
| GET | 頁面跳轉(zhuǎn) | 文件對應(yīng)的 URL |
| POST | AJAX | 文件的二進(jìn)制流 |
首先,需要在 src/service/api.js 里聲明對應(yīng)請求返回的文件類型:
import request from '@/utils/request';
export async function Download(params = {}) {
return request(`/api/download`, {
method: 'POST', // GET / POST 均可以
data: params,
responseType : 'blob', // 必須注明返回二進(jìn)制流
});
}
然后在對應(yīng)的 Model 里編寫相關(guān)請求處理的業(yè)務(wù)邏輯:
import { message } from 'antd';
import { Download } from '@/services/api';
export default {
namespace: 'download',
state: {},
effects: {
*download({ payload, callback }, { call }){
const response = yield call(Download, payload);
if (response instanceof Blob) {
if (callback && typeof callback === 'function') {
callback(response);
}
} else {
message.warning('Some error messages...', 5);
}
}
},
reducers: {},
}
最后編寫頁面組件相關(guān)業(yè)務(wù)邏輯,點擊下載按鈕,派發(fā)下載 action 到 model :
import React, { Component } from 'react';
import { Button } from 'antd';
import { connect } from 'dva';
@connect(({ download, loading }) => ({
download,
loading: loading.effects['download/download'],
}))
class ExampleDownloadPage extends Component {
handleDownloadClick = e => {
e.preventDefault();
const { dispatch } = this.props;
const fileName = 'demo.xlsx';
dispatch({
type: 'download/download',
payload: {}, // 根據(jù)實際情況填寫參數(shù)
callback: blob => {
if (window.navigator.msSaveOrOpenBlob) {
navigator.msSaveBlob(blob, fileName);
} else {
const link = document.createElement('a');
const evt = document.createEvent('MouseEvents');
link.style.display = 'none';
link.href = window.URL.createObjectURL(blob);
link.download = fileName;
document.body.appendChild(link); // 此寫法兼容可火狐瀏覽器
evt.initEvent('click', false, false);
link.dispatchEvent(evt);
document.body.removeChild(link);
}
}
});
}
render(){
const { loading } = this.props;
return <Button
loading={loading}
icon="download"
onClick={this.handleDownloadClick}
>
下載
</Button>;
}
}
大功告成!~~
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
bootstrap與pagehelper實現(xiàn)分頁效果
這篇文章主要為大家詳細(xì)介紹了bootstrap與pagehelper實現(xiàn)分頁效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-12-12
BootstrapValidator超詳細(xì)教程(推薦)
這篇文章主要介紹了BootstrapValidator超詳細(xì)教程(推薦)的相關(guān)資料,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2016-12-12
JS代碼屏蔽F12,右鍵,粘貼,復(fù)制,剪切,選中,操作實例
在本篇文章里小編給大家分享的是關(guān)于利用JS代碼屏蔽F12,右鍵,粘貼,復(fù)制,剪切,選中,操作,需要的朋友們學(xué)習(xí)下。2019-09-09
Bootstrap教程JS插件彈出框?qū)W習(xí)筆記分享
這篇文章主要為大家分享了Bootstrap教程JS插件彈出框?qū)W習(xí)筆記,為大家詳細(xì)介紹Bootstrap彈出框的使用方法,感興趣的小伙伴們可以參考一下2016-05-05
js實現(xiàn)網(wǎng)站最上邊可關(guān)閉的浮動廣告條代碼
這篇文章主要介紹了js實現(xiàn)網(wǎng)站最上邊可關(guān)閉的浮動廣告條代碼,涉及javascript基于鼠標(biāo)事件操作頁面元素樣式的實現(xiàn)技巧,需要的朋友可以參考下2015-09-09
bootstrap日歷插件datetimepicker使用方法
這篇文章主要為大家詳細(xì)介紹了bootstrap日歷datetimepicker插件的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-12-12
ES6學(xué)習(xí)教程之Map的常用方法總結(jié)
Map 是 ES6 中新增的一種數(shù)據(jù)結(jié)構(gòu),與 Set 一起添加,其實功能都差不多。下面這篇文章主要給大家總結(jié)介紹了關(guān)于ES6學(xué)習(xí)教程之Map的常用方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2017-08-08

