vue 项目中 base64格式文件下载

11 篇文章 1 订阅

vue 项目中 base64格式文件下载

在这里插入图片描述
其中 this.info 是里包含后端返回的base64文件
数据结构如图
在这里插入图片描述

<template>
  <div>
    <el-dialog
      :title="title"
      width="40%"
      :visible.sync="visible"
      :before-close="onClose"
      :close-on-click-modal="false"
      v-on="$listeners"
    >

      <el-alert
        :title="info.msg"
        type="warning"

        :closable="false"
      />

      <p>
        <el-button
          size="small"
          type="text"

          :loading="loading"
          @click.stop="downloadFun"
        >下载文件</el-button>

      </p>

      <div slot="footer" class="dialog-footer">
        <el-button @click="onClose">取消</el-button>
      </div>

    </el-dialog>

  </div>
</template>

<script>

export default {
  props: {
    visible: {
      type: Boolean,
      default: true
    },
    info: {
      type: Object,
      default: () => {}
    }
  },
  data() {
    return {
      title: '',
      loading: false
    }
  },
  mounted() {
    // console.log(this.info, 'info')
    this.title = this.info.extra.fileName
  },
  methods: {
    onClose() {
      this.$emit('update:visible', false)
    },
    downloadFun() {
      this.loading = true

      const blob = this.dataURLtoBlob(this.info.extra.fileStream)
      const link = document.createElement('a')
      link.style.display = 'none'
      link.href = URL.createObjectURL(blob)
      link.setAttribute('download', this.info.extra.fileName)
      document.body.appendChild(link)
      link.click()

      this.loading = false
    },
    dataURLtoBlob(base64Str) {
      var bstr = atob(base64Str); var n = bstr.length; var u8arr = new Uint8Array(n)
      while (n--) {
        u8arr[n] = bstr.charCodeAt(n)
      }
      // 下载的是excel格式的文件
      return new Blob([u8arr], { type: 'application/vnd.ms-excel' })
    }

  }
}
</script>

<style lang="scss" scoped>

</style>

  • 4
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
要在 Vue2.0 项目base64 格式的图片插入到 xlsx 文件下载该文件,可以使用 js-xlsx 库来实现。 首先,安装 js-xlsx 库: ``` npm install xlsx --save ``` 然后,在需要生成 xlsx 文件的组件引入库: ``` import XLSX from 'xlsx'; ``` 接着,定义一个方法来生成 xlsx 文件: ``` methods: { downloadExcel() { // 创建一个工作簿 const wb = XLSX.utils.book_new(); // 创建一个工作表 const ws = XLSX.utils.json_to_sheet([{ name: '张三', age: 18, avatar: '...' }]); // 将图片插入到工作表 const img = new Image(); img.src = '...'; const imageData = XLSX.utils.img_to_data_uri(await this.getBlob(img)); XLSX.utils.sheet_add_image(ws, imageData, 'A2'); // 将工作表添加到工作簿 XLSX.utils.book_append_sheet(wb, ws, 'Sheet1'); // 生成文件并下载 XLSX.writeFile(wb, 'example.xlsx'); }, // 获取图片 blob 对象 getBlob(img) { return new Promise((resolve) => { const canvas = document.createElement('canvas'); const ctx = canvas.getContext('2d'); canvas.width = img.width; canvas.height = img.height; ctx.drawImage(img, 0, 0, img.width, img.height); canvas.toBlob((blob) => { resolve(blob); }, 'image/png', 1); }); }, }, ``` 其,`downloadExcel` 方法用来生成和下载 xlsx 文件。首先,创建一个工作簿和一个工作表,然后将图片插入到工作表。图片需要先转换成 data-uri 格式,然后调用 `XLSX.utils.sheet_add_image` 方法将图片插入到指定位置。最后,将工作表添加到工作簿,调用 `XLSX.writeFile` 方法生成文件并下载。 `getBlob` 方法用来将图片转换成 blob 对象,方便后续操作。 需要注意的是,图片需要提前加载完成才能对其进行操作,因此建议使用 async/await 来处理。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值