亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Ant Design Pro 下實(shí)現(xiàn)文件下載的實(shí)現(xiàn)代碼

 更新時(shí)間:2019年12月03日 08:31:15   作者:JasonHe  
這篇文章主要介紹了Ant Design Pro 下實(shí)現(xiàn)文件下載的實(shí)現(xiàn)代碼,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

最近編寫(xiě)在頁(yè)面內(nèi)通過(guò) AJAX 請(qǐng)求服務(wù)器下載文件遇到一些問(wèn)題,網(wǎng)上找的資料和介紹大多不健全不系統(tǒng),最終自己摸索出來(lái)的解決方案,先簡(jiǎn)單寫(xiě)個(gè)初稿,后面再詳細(xì)補(bǔ)充。

表一:前端請(qǐng)求后端下載文件的各種情況

請(qǐng)求方法 請(qǐng)求方式 響應(yīng)結(jié)果
GET 頁(yè)面跳轉(zhuǎn) 文件對(duì)應(yīng)的 URL
POST AJAX 文件的二進(jìn)制流

首先,需要在 src/service/api.js 里聲明對(duì)應(yīng)請(qǐng)求返回的文件類(lèi)型:

import request from '@/utils/request';

export async function Download(params = {}) {
 return request(`/api/download`, {
  method: 'POST', // GET / POST 均可以
  data: params,
  responseType : 'blob', // 必須注明返回二進(jìn)制流
 });
}

然后在對(duì)應(yīng)的 Model 里編寫(xiě)相關(guān)請(qǐng)求處理的業(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: {},
}

最后編寫(xiě)頁(yè)面組件相關(guān)業(yè)務(wù)邏輯,點(diǎn)擊下載按鈕,派發(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í)際情況填寫(xiě)參數(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); // 此寫(xiě)法兼容可火狐瀏覽器
          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>;
  }
}

大功告成!~~

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

相關(guān)文章

  • 淺談gulp創(chuàng)建完整的項(xiàng)目流程

    淺談gulp創(chuàng)建完整的項(xiàng)目流程

    本篇文章主要介紹了淺談gulp創(chuàng)建完整的項(xiàng)目流程,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-12-12
  • JavaScript檢測(cè)彈出窗口是否已經(jīng)關(guān)閉的方法

    JavaScript檢測(cè)彈出窗口是否已經(jīng)關(guān)閉的方法

    這篇文章主要介紹了JavaScript檢測(cè)彈出窗口是否已經(jīng)關(guān)閉的方法,涉及javascript中window屬性的closed屬性的使用技巧,需要的朋友可以參考下
    2015-03-03
  • 如何使用JS在HTML中自定義字符串格式化

    如何使用JS在HTML中自定義字符串格式化

    在JavaScript中雖沒(méi)有類(lèi)似的方法,但我們可以利用字符串的replace方法自定義字符串的格式化方法。下面通過(guò)本文給大家分享使用JS在HTML中自定義字符串格式化的方法,需要的的朋友參考下吧
    2017-07-07
  • js實(shí)現(xiàn)可愛(ài)的氣泡特效

    js實(shí)現(xiàn)可愛(ài)的氣泡特效

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)可愛(ài)的氣泡特效,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2020-09-09
  • JS實(shí)現(xiàn)雙擊編輯可修改狀態(tài)的方法

    JS實(shí)現(xiàn)雙擊編輯可修改狀態(tài)的方法

    這篇文章主要介紹了JS實(shí)現(xiàn)雙擊編輯可修改狀態(tài)的方法,涉及javascript針對(duì)頁(yè)面元素的動(dòng)態(tài)創(chuàng)建及設(shè)置技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-08-08
  • js自動(dòng)生成的元素與頁(yè)面原有元素發(fā)生堆疊的解決方法

    js自動(dòng)生成的元素與頁(yè)面原有元素發(fā)生堆疊的解決方法

    js自動(dòng)生成的元素與頁(yè)面原有元素發(fā)生堆疊通過(guò)去除浮動(dòng),給原有元素(商品擴(kuò)展信息部分)加上clear:both; 果然正常了
    2013-10-10
  • js彈出div并顯示遮罩層

    js彈出div并顯示遮罩層

    彈出div顯示遮罩層的效果,想必大家都有見(jiàn)到過(guò)吧,下面有個(gè)示例,大家可以參考下
    2014-02-02
  • js插件dropload上拉下滑加載數(shù)據(jù)實(shí)例解析

    js插件dropload上拉下滑加載數(shù)據(jù)實(shí)例解析

    這篇文章主要為大家詳細(xì)解析了js插件dropload上拉下滑加載數(shù)據(jù)實(shí)例,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-07-07
  • 淺析2種JavaScript繼承方式

    淺析2種JavaScript繼承方式

    這篇文章主要介紹了2種JavaScript主要繼承方式,一種是通過(guò)原型的方式,一種是通過(guò)借用call&apply的構(gòu)造函數(shù)方式,感興趣的小伙伴們可以參考一下
    2015-12-12
  • JavaScript異步編程操作實(shí)現(xiàn)介紹

    JavaScript異步編程操作實(shí)現(xiàn)介紹

    異步(Asynchronous, async)是與同步(Synchronous, sync)相對(duì)的概念。在我們學(xué)習(xí)的傳統(tǒng)單線程編程中,程序的運(yùn)行是同步的,同步不意味著所有步驟同時(shí)運(yùn)行,而是指步驟在一個(gè)控制流序列中按順序執(zhí)行,而異步的概念則是不保證同步的概念
    2022-09-09

最新評(píng)論