实战:JS批量打包下载图片--(zip压缩)

17 篇文章 1 订阅

1.下载两个插件

npm i -s jszip file-saver

2.封装函数如下:

// 在JS文件中引入这两个插件
import JSZip from 'jszip'
import FileSaver from 'file-saver'

/**
 * 获取图片的 base64 编码
 * @param image 图像对象
 * @return {string} 返回base64编码
 */
const getImageBase64  = image => {
  const canvas = document.createElement('canvas')
  canvas.width = image.width
  canvas.height = image.height
  const ctx = canvas.getContext('2d')
  ctx.drawImage(image, 0, 0, image.width, image.height)
  // 获取图片后缀名
  const extension = image.src
    .substring(image.src.lastIndexOf('.') + 1)
    .toLowerCase()
  // 某些图片 url 可能没有后缀名,默认是 png
  return canvas.toDataURL('image/' + extension, 1)
}

/**
 * 批量下载图片
 * @param sourceList图像数据
 * @param zipName // 下载时的文件夹名称
 * @param sourceList[i].picName // 每张图片的名称--注意: 需要对数据属性进行转换
 */
export const downloadZip = async(sourceList, zipName = '文件夹名称') => {
  const zip = new JSZip()
  const fileFolder = zip.folder(zipName) // 创建 zipName 文件夹
  const fileList = []
  for (let i = 0; i < sourceList.length; i++) {
    const name = sourceList[i].picName // 注意: 每张图片的名称--需要对数据属性进行转换
    const image = new Image()
    image.setAttribute('crossOrigin', 'Anonymous') // 设置 crossOrigin 属性,解决图片跨域报错
    image.src = sourceList[i].qrCode
    image.onload = async() => {
      const url = await getImageBase64(image)
      fileList.push({ name: name, img: url.substring(22) }) // 截取 data:image/png;base64, 后的数据
      if (fileList.length === sourceList.length) {
        if (fileList.length) {
          for (let k = 0; k < fileList.length; k++) {
          	// 往文件夹中,添加每张图片数据
            fileFolder.file(fileList[k].name + '.png', fileList[k].img, {
              base64: true
            })
          }
          zip.generateAsync({ type: 'blob' }).then(content => {
            FileSaver.saveAs(content, zipName + '.zip')
          })
        }
      }
    }
  }
}
  1. sourceList 数据结构
sourceList = [
      {
        id: 1,
        qrCode:
          'https://baidu.com.cn/Hk4ZhTv46Qb57l_1234',
        picName: '图片1'
      },
      {
        id: 2,
        qrCode:
          'https://baidu.com.cn/Hk4ZhdTv46Qb57l_12346',
        picName: '图片2'
      }
    ]
  • 3
    点赞
  • 12
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值