node端
第一步 先创建一个路由

'use strict'

/**
 * @param {Egg.Application} app - egg application
 */

module.exports = ({
  router,
  controller: {
    searchStastics: {
      searchRanking,
    },
  },
}) => {
  // 搜索排行导出
  router.get('/search/search_ranking_export', searchRanking.searchRankingExport)
}

第二步:
controller

  /**
   * 搜索排行列表导出
   */
  async searchRankingExport() {
    await this.searchCommomExport('/search/ranking')
  }
 /**
   * 搜索排行/搜索记录导出
   * @param { String} url 传入的接口
   */
  async searchCommomExport(url) {
    // 后台需要秒,同一个接口csv=1表示导出,不传或者为0表示正常的列表
    const { service } = this
    const query = await this.searchCommon()
    query.csv = 1
    const data = await service.common.tarsServer.tarsServerHttp(url, {
      dataType: 'buffer',
      data: query,
    })
    this.ctx.set('Content-disposition', 'attachment; filename="write.xlsx"')
    this.ctx.set('Content-type', 'application/octet-stream')
    this.ctx.body = data
  }
  /**
   * 搜索排行/搜索记录列表和导出的公共参数
   */
  async searchCommon() {
    const { ctx } = this
    const { startTime, endTime, ...params } = ctx.request.query
    return {
      startTime: Math.round(startTime / 1000),
      endTime: Math.round(endTime / 1000),
      ...params,
    }
  }

第三步 前端自己调用

const exportExcelUrl = '/user_exchange_record/export'
export function exportFile(url, params) {
  return request({
    responseType: 'blob',
    headers: {
      'Content-Type': 'application/json',
    },
    timeout: 1000 * 60,
    url: url,
    method: 'get',
    params,
  })
}
async exportFileFun() {
  const file = await exportFile(this.exportItem.apiUrl, res)
  this.saveFile(file, '文件下载')
},

saveFile(file, filename) {
  const ieKit = /(?:ms|\()(ie)\s([\w\.]+)|trident|(edge|edgios|edga|edg)/i.test(window.navigator.userAgent)
  const blobData = new Blob([file], { type: 'application/vnd.ms-excel' })
  if (ieKit) {
    navigator.msSaveBlob && navigator.msSaveBlob(blobData, filename)
  } else {
    const objectURL = window.URL.createObjectURL(blobData)
    const save_link = document.createElement('a')
    const event = document.createEvent('MouseEvents')
    save_link.href = objectURL
    save_link.download = filename + '.xlsx'
    event.initMouseEvent('click', true, false, window, 0, 0, 0, 0, 0, false, false, false, false, 0, null)
    save_link.dispatchEvent(event)
    window.URL.revokeObjectURL(objectURL)
  }
},

node 端怎么通过exceljs实现excel的导出 请查看https://www.cnblogs.com/antyhouse/p/13256093.html

posted on 2020-07-06 18:28  周小姐你好  阅读(346)  评论(0编辑  收藏  举报