Axios实现pdf预览

Axios实现pdf预览

注:
1.blob转码会随机生成字符串,会与PDF文件名不一致
2.若需token,需后端进行过滤(或可选传递token)
3.确保后端是部署在tomcat

    //PDF预览
    pdfPreview(param) {
      let obj = {
        wjlj:参数
      }
      postAction(this.url.pdfPreview, obj).then((res) => {
        if (res.success) {
          const url = '/downfile?filePath=' + res.result
          this.getPdfCode(url)
        } else {
        }
      })
    },
    // 初始化获取pdf文件
    getPdfCode(filePath) {
      axios({
        method: 'get',
        url: filePath,
        headers: {
          'Content-Type': 'application/vnd.openxmlformats-officedocument.spreadsheetml.sheet'
        },
        responseType: 'blob' //设置响应的数据类型为一个包含二进制数据的 Blob 对象,必须设置!!!
      })
        .then((response) => {
          console.log(response)
          const binaryData = []
          binaryData.push(response)
          if (binaryData[0].size === 0) {
            this.$message.warning('无附件时的提示')
          } else {
            //获取blob链接
            let pdfUrl = window.URL.createObjectURL(new Blob(binaryData, { type: 'application/pdf' }))
            window.open(pdfUrl, '_blank')
          }
        })
    },
### Vue2 中实现 PDF 文件在线预览 #### 使用 `vue-pdf` 库实现 PDF 预览 为了在 Vue2 项目中实现 PDF 文件的在线预阅,可以采用 `vue-pdf` 这一专门用于渲染 PDF 的组件库[^3]。 安装 `vue-pdf`: ```bash npm install vue-pdf ``` 创建一个简单的 Vue 组件来加载并显示 PDF 文档: ```html <template> <div class="pdf-viewer"> <!-- 加载指定页数 --> <pdf :src="url"></pdf> </div> </template> <script> import pdf from 'vue-pdf' export default { components: { pdf, }, data() { return { url: '/path/to/your.pdf', } } } </script> ``` 如果需要处理来自服务器端返回的二进制流形式的 PDF 数据,则可以根据提供的函数进一步调整代码逻辑以适应需求[^2]。此时应先通过 AJAX 请求获取到 Blob 类型的数据对象再将其传递给 `vue-pdf` 来解析展示。 对于从 API 接口接收 PDF 流的情况,可利用 Axios 或其他 HTTP 客户端发送请求,并确保设置了正确的响应类型 (`responseType`) 和编码方式(`contentType`)以便正确读取数据。 ```javascript // 假设已引入 axios 并配置好基础路径等信息 axios.post('/layout/api/view', formData, { responseType: 'blob' }).then(response => { const file = new File([response.data], 'temp.pdf', { type: 'application/pdf' }); this.url = URL.createObjectURL(file); }); ``` 上述方法能够有效地支持基于 Vue2 构建的应用程序完成对本地存储或是远程服务上 PDF 资源的有效浏览操作[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值