Vue3使用PDFJS将后端查到的二进制数据转为图片

如果想实现将后端二进制转pdf请看我另一篇文章

VUE3中使用PDF.js实现二进制转PDF预览功能_pdfjs 二进制-CSDN博客
代码如下:

<template>
<img :src="imageUrl" style=" width: 267.3mm; max-height: 189mm" />
</template>

const imageUrl = ref();
imageUrl.value = await convertPdfPageToImageUrl(data);

async function convertPdfPageToImageUrl(pdfData) {
    GlobalWorkerOptions.workerSrc = "/public/static/pdf/build/pdf.worker.mjs";
    const loadingTask = await getDocument({ data: pdfData });
    const pdfDocument = await loadingTask.promise;
    const pageNumber = 1;
    const pdfPage = await pdfDocument.getPage(pageNumber);

    const canvas = document.createElement("canvas");
    const context = canvas.getContext("2d");

    const viewport = pdfPage.getViewport({ scale: 1.0 });
    canvas.width = viewport.width;
    canvas.height = viewport.height;

    await pdfPage.render({
      canvasContext: context!,
      viewport: viewport
    }).promise;
    return canvas.toDataURL("image/png");
  }

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue.js 是一个行的前端框架,用于构建用户界面。如果你需要在 Vue 应用中实现 PDF 文件换为图片并预览,你可以使用一些第三方库来辅助完成这个功能。以下是一个简单的步骤和推荐的库: 1. **安装依赖**:首先,你需要安装一个叫做 `html2canvas` 的库,它是一个 JavaScript 库,能够将 HTML 内容换为 canvas,然后你可以选择另一个库如 `pdfjs-dist` 来处理 PDF 文件。 ``` npm install html2canvas pdfjs-dist ``` 2. **PDF 预加载**:使用 `pdfjs-dist` 加载 PDF 文件并解析。 ```javascript import { PDFJS } from 'pdfjs-dist'; PDFJS.getDocument('your_pdf_url_or_file_path').promise.then(pdf => { // 处理PDF内容 }); ``` 3. **换为HTML**:当PDF加载完成后,将其换为可渲染的HTML元素。 ```javascript const render PDFPage to HTML = async (page) => { const container = document.createElement('div'); const viewport = page.getViewport({ scale: 1 }); container.style.width = `${viewport.width}px`; container.style.height = `${viewport.height}px`; container.innerHTML = await page.renderTextContent({ layoutMode: 'canvas' }); return container; }; ``` 4. **图片预览**:使用 `html2canvas` 将HTML换为图片。 ```javascript html2canvas(render(pdf.getPage(i))).then(canvas => { // 在Vue组件中显示或保存图片 this.previewImage = canvas.toDataURL(); }); ``` 5. **Vue组件实现**:在 Vue 组件中,你可以根据需要调用这些方法,比如在一个按钮点击事件中。 记得在实际项目中处理好错误处理和用户体验,例如进度条展示、PDF加载失败的提示等。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值