vue下载图片常见问题,解决vue中下载同源图片、跨域图片,以及打包下载多个跨域图片

在网上查了很多资料,发现很多都是html+js,jquery实现图片下载的,于是整理了一份在vue中下载的方式,总结如下:

一、使用axios下载同源图片

原理:创建一个a标签并隐藏掉,将axios返回的图片路径赋值给href,a标签的dowmload属性不设置时浏览器会直接打开href路径,设置了之后会强制将文件下载下来,我们就用这一方式下载图片,加载完之后再将a标签移除,此方式只针对同源图片。

<el-button type="primary" @click="handleDownload(this.imgurl,'photo.jpg')">下载同源图片</el-button>

js代码:

import axios from 'common/js/axios'  // 引入配置的axios


// imgUrl为图片路径,fileName为文件名
handleDownload(imgUrl, fileName){
  axios
  .get(imgUrl, { responseType: 'arraybuffer' })
  .then((res) => {
    const blob = new Blob([res.data])
    const blobUrl = window.URL.createObjectURL(blob)
    // 创建a标签并隐藏 设置标签属性为download时会强制下载
    const a = document.createElement('a')
    a.style.display = 'none'
    a.href = blobUrl
    a.setAttribute('download', fileName)
    // 清除a标签
    document.body.appendChild(a)
    a.click()
    document.body.removeChild(a)
    window.URL.revokeObjectURL(blobUrl)
  })
}

二、创建canvas下载跨域图片

原理:当图片域名跟当前域名不同时,创建一个canvas,把图片转成base64的格式,再赋值给a标签,就可以下载了。

<el-button type="primary" @click="handleDownload(this.imgurl,'photo.jpg')">下载跨域图片</el-button>

js代码:

// 下载点击事件
handleDownload(this.imgUrl, 'photo.jpg').then(() => {
  this.$message.success('成功下载1张图片!')
})


// 下载图片
downloadImg(imgsrc, fileName) {
  let image = new Image()
  // 解决跨域 Canvas 污染问题
  image.setAttribute('crossOrigin', 'anonymous')
  image.onload = function() {
    let canvas = document.createElement('canvas')
    canvas.width = image.width
    canvas.height = image.height
    let context = canvas.getContext('2d')
    context.drawImage(image, 0, 0, image.width, image.height)
    let url = canvas.toDataURL('image/png') // 得到图片的base64编码数据
    let a = document.createElement('a') // 生成一个a元素
    let event = new MouseEvent('click') // 创建一个单击事件
    a.download = fileName || 'photo' // 设置图片名称
    a.href = url // 将生成的URL设置为a.href属性
    a.dispatchEvent(event) // 触发a的单击事件
  }
  image.src = imgsrc
  return Promise.resolve()
}

三、将多个图片打包成zip,下载下来

用到的插件:

npm install jszip

npm install file-saver

<el-button type="primary" @click="handleDownloadAll(this.imgList)">下载所有图片</el-button>

js代码: 

    // 引入插件
    import JSZip from 'jszip'
    import { saveAs } from 'file-saver'


    // 批量下载图片
    handleDownloadAll(imgList) {
      const that = this
      var imgBase64 = []
      var imageSuffix = [] // 图片后缀
      var zip = new JSZip()
      var img = zip.folder('文件夹名')
      for (var i = 0; i < imgList.length; i++) {
        // 获取每个图片的后缀
        var suffix = imgList[i].substring(imgList[i].lastIndexOf('.'))
        imageSuffix.push(suffix)

        this.getBase64(imgList[i])
          .then(base64 => {
            imgBase64.push(base64.substring(22))
          }, err => {
            console.log(err) // 打印异常信息
          })
      }

      function tt () {
        setTimeout(function () {
          if (imgList.length === imgBase64.length) {
            for (var i = 0; i < imgList.length; i++) {
              // 设置文件名
              img.file(i + imageSuffix[i], imgBase64[i], { base64: true })
            }
            zip.generateAsync({ type: 'blob' }).then(function (content) {
              // see FileSaver.js
              saveAs(content, '压缩包名.zip')
              that.$message.success(`成功下载${imgList.length}张图片!`)
            })
          } else {
            tt()
          }
        }, 100)
      }
      tt()
    },


    getBase64 (img) {
      // width、height调用时传入具体像素值,控制大小 ,不传则默认图像大小
      function getBase64Image (img, width, height) {
        var canvas = document.createElement('canvas')
        canvas.width = width || img.width
        canvas.height = height || img.height

        var ctx = canvas.getContext('2d')
        ctx.drawImage(img, 0, 0, canvas.width, canvas.height)
        var dataURL = canvas.toDataURL()
        return dataURL
      }
      return new Promise((resolve) => {
        var image = new Image()
        image.crossOrigin = 'Anonymous'
        image.src = img
        if (img) {
          image.onload = function () {
            // 读取图片之后的操作
            resolve(getBase64Image(image))
          }
        }
      })
    },

  • 2
    点赞
  • 13
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue,要实现跨域下载图片,可以使用以下方法: 1. 首先,你需要在Vue组件引入axios库。可以在`<script>`标签添加以下代码: ```javascript import axios from 'axios' ``` 2. 接下来,你可以在Vue组件定义一个方法来处理图片下载。例如,你可以创建一个名为`downloadImage`的方法,并传入图片的URL和文件名作为参数: ```javascript methods: { downloadImage(imgUrl, fileName) { axios.get(imgUrl, { responseType: 'blob' }) .then(response => { const url = window.URL.createObjectURL(new Blob([response.data])) const link = document.createElement('a') link.href = url link.setAttribute('download', fileName || 'image') document.body.appendChild(link) link.click() }) .catch(error => { console.error(error) }) } } ``` 3. 最后,在Vue模板,你可以通过点击事件调用`downloadImage`方法来下载图片。例如,你可以在一个按钮上绑定点击事件,并传入图片的URL和文件名: ```html <el-button type="primary" @click="downloadImage('http://example.com/image.jpg', 'photo.jpg')">下载图片</el-button> ``` 以上代码将会通过axios库发送一个GET请求来获取图片的二进制数据,并创建一个URL对象来生成下载链接。然后,创建一个`<a>`标签,并将生成的URL设置为`href`属性。最后,模拟点击`<a>`标签来触发下载操作。 请注意,以上代码是基于Vue和axios的实现方式。确保在使用前安装并导入axios库。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [vue下载图片常见问题解决vue下载同源图片跨域图片,以及打包下载多个跨域图片](https://blog.csdn.net/m0_50744582/article/details/127930626)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatgptT3_2"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值