当前位置: 首页 > article >正文

vue3 pdf base64转成文件流打开

vue3 pdf base64转成文件流打开

1、先下载依赖

“vue-pdf”: “^4.3.0”,
“canvas”: “^2.11.2”,
“pdfh5”: “^1.4.0”,
“pdfjs-dist”: “2.5.207”,

2、文件流转换

 const getList = async () => {
    const res = await TH36({
      query_type: '2',
      start_date: data.start_date,
      end_date: data.end_date,
    })
    console.log(res)
    if (res.data.head.errorFlag != 0) {
      Toast(res.data.head.errorMsg)
    } else {
      // data.base64Url = 'data:image/png;base64,' + res.data.data.result.pdf
      data.base64Url = 'data:application/pdf;base64,' + res.data.data.result.pdf
      viewPdf(res.data.data.result.pdf)
    }
  }
  // content是base64格式
  const viewPdf = (content) => {
    // console.log('content', content)
    const blob = base64ToBlob(content)
    // if (window.navigator && window.navigator.msSaveOrOpenBlob) {
    //   console.log('1:', blob)
    //   window.navigator.msSaveOrOpenBlob(blob)
    // } else {
    const fileURL = URL.createObjectURL(blob)
    console.log('2:', fileURL)
    // window.location.href = fileURL //打开ppf文件
    router.push({
      path: '/service/equityRecordFormDetail',
      query: {
        url: fileURL,
      },
    })
    // }
  }
  const base64ToBlob = (code) => {
    code = code.replace(/[\n\r]/g, '') // 检查base64字符串是否符合base64编码
    // atob() 方法用于解码使用 base-64 编码的字符串。
    const raw = window.atob(code)
    const rawLength = raw.length
    const uInt8Array = new Uint8Array(rawLength)
    for (let i = 0; i < rawLength; ++i) {
      // 将解码后的逐个字符转换成Unicode序号,放入Unit8Array数组
      uInt8Array[i] = raw.charCodeAt(i)
    }
    // 通过Blob将Uint8Array数组转换成pdf类型的文件对象
    return new Blob([uInt8Array], { type: 'application/pdf' })
  }

3、打开pdf

<template>
  <div id="app">
    <div id="demo"></div>
  </div>
</template>

<script setup>
  import { reactive, toRefs, onMounted } from 'vue'
  import { useRoute } from 'vue-router'
  import Pdfh5 from 'pdfh5'
  import 'pdfh5/css/pdfh5.css'
  const route = useRoute()
  const id = route.query.id
  const data = reactive({
    pdfh5: null,
    PDFsrc: route.query.url,
  })
  onMounted(() => {
    //实例化
    data.pdfh5 = new Pdfh5('#demo', {
      pdfurl: data.PDFsrc,
    })
    //监听完成事件
    data.pdfh5.on('complete', function (status, msg, time) {
      console.log(
        '状态:' +
          status +
          ',信息:' +
          msg +
          ',耗时:' +
          time +
          '毫秒,总页数:' +
          data.totalNum
      )
    })
  })
  const { content } = toRefs(data)
</script>

<style lang="scss" scoped>
  * {
    padding: 0;
    margin: 0;
  }
  html,
  body,
  #app {
    width: 100%;
    height: 100%;
  }
  #demo {
    height: 100vh;
    overflow: hidden;
    overflow-y: scroll;
  }
</style>


http://www.kler.cn/a/384626.html

相关文章:

  • ubuntu 20.04 NVIDIA驱动、cuda、cuDNN安装
  • 计算不停歇,百度沧海数据湖存储加速方案 2.0 设计和实践
  • Vue2 doc、excel、pdf、ppt、txt、图片以及视频等在线预览
  • Unity3D UI 拖拽
  • 分离编译(介绍,解决“类模板定义和声明不在同一文件导致链接错误“的问题),类模板实例化原理,
  • 云计算答案
  • 阿里云函数计算GBK编码
  • 开源代码管理平台Gitlab如何本地化部署并实现公网环境远程访问私有仓库
  • 来咯来咯webSocket
  • JavaEE初阶---servlet篇(二)(smartTomcat的使用相关错误类型)
  • 【智能算法应用】哈里斯鹰算法优化二维栅格路径规划问题
  • CoEdge: 面向自动驾驶的协作式边缘计算系统,实现分布式实时深度学习任务的高效调度与资源优化
  • ruoyi-vue中的mybatis改为mybatis-plus
  • 【数据结构-合法括号字符串】【hard】【拼多多面试题】力扣32. 最长有效括号
  • 阿里云对象存储OSS
  • 恋爱脑学Rust之智能指针Rc,RefCell和Weak指针
  • 重构代码之添加参数
  • [单例模式]
  • 【设计模式系列】桥接模式(十三)
  • LLMs之PDF:zeroX(一款PDF到Markdown 的视觉模型转换工具)的简介、安装和使用方法、案例应用之详细攻略
  • uniapp中使用原生ajax上传文件并携带其他数据,实时展示上传进度
  • 外包干了2年,快要废了。。。
  • [Element] el-table修改滚动条上部分的背景色
  • 科比投篮预测——数据处理与分析
  • ES6的Proxy到底是什么?
  • LINUX下的Mysql:Mysql基础