HahahahiaZhang 2023-01-31 00:13 采纳率: 100%
浏览 160
已结题

前端vue实现根据图片url生成pdf文件

获取到当前页面多个图片的url后,如何实现将这些图片转成一个pdf文件并下载呢?
只要前端,不要后端

  • 写回答

13条回答 默认 最新

  • Lingjie Fan 2023-01-31 05:44
    关注

    在前端 vue 中实现根据图片 URL 生成 PDF 文件的基本流程如下:

    安装并引入 PDF 生成库,例如 jspdf。
    定义一个函数,用于生成 PDF 文件。
    利用 JavaScript 的 Canvas API,将图片 URL 转换为图片数据。
    利用 PDF 生成库,在 PDF 文件中添加图片数据。
    利用 JavaScript 的 Blob API 或者 saveAs 库,将 PDF 文件保存到本地并下载。
    下面是一个实现根据图片 URL 生成 PDF 文件并下载的代码示例:

    // 1. 安装并引入 jspdf
    import JsPDF from 'jspdf'
    
    // 2. 定义生成 PDF 文件的函数
    function generatePDF(imgUrls) {
      // 3. 利用 Canvas API 转换图片 URL 为图片数据
      const promises = imgUrls.map(url => {
        return new Promise(resolve => {
          const canvas = document.createElement('canvas')
          const ctx = canvas.getContext('2d')
          const img = new Image()
          img.onload = function() {
            canvas.width = img.width
            canvas.height = img.height
            ctx.drawImage(img, 0, 0)
            resolve(canvas.toDataURL('image/png'))
          }
          img.src = url
        })
      })
    
      // 4. 生成 PDF 文件
      Promise.all(promises).then(images => {
        const pdf = new JsPDF()
        images.forEach((image, i) => {
          pdf.addImage(image, 'PNG', 0, 0)
          if (i !== images.length - 1) {
            pdf.addPage()
          }
        })
    
        // 5. 下载 PDF 文件
        pdf.save('images.pdf')
      })
    }
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(12条)

报告相同问题?

问题事件

  • 系统已结题 2月15日
  • 已采纳回答 2月7日
  • 修改了问题 2月1日
  • 创建了问题 1月31日

悬赏问题

  • ¥15 AT89C52单片机C语言串口助手发送数据包返回值
  • ¥15 C++数组中找第二小的数字程序纠错
  • ¥50 MATLAB APP 制作出现问题
  • ¥15 wannier复现图像时berry曲率极值点与高对称点严重偏移
  • ¥15 利用决策森林为什么会出现这样·的问题(关键词-情感分析)
  • ¥15 DispatcherServlet.noHandlerFound No mapping found for HTTP request with URI[/untitled30_war_e
  • ¥15 使用deepspeed训练,发现想要训练的参数没有梯度
  • ¥15 寻找一块做为智能割草机的驱动板(标签-stm32|关键词-m3)
  • ¥15 信息管理系统的查找和排序
  • ¥15 基于STM32,电机驱动模块为L298N,四路运放电磁传感器,三轮智能小车电磁组电磁循迹(两个电机,一个万向轮),怎么用读取的电磁传感器信号表示小车所在的位置