vue-pdf-embed 预览文件流
时间: 2025-01-10 19:49:45 浏览: 144
### 使用 `vue-pdf-embed` 预览 PDF 文件流
为了使用 `vue-pdf-embed` 组件来预览来自文件流的PDF文档,需先通过 npm 安装该库以及其依赖项[^1]。
#### 安装必要的包
```bash
npm install vue-pdf-embed
npm install pdfjs-dist
```
一旦完成安装,在Vue组件内部可以按照如下方式引入并配置:
#### 创建 Vue 组件以加载 PDF 流数据
```javascript
import { ref, onMounted } from 'vue';
import PdfEmbed from "vue-pdf-embed";
export default {
components: {
PdfEmbed,
},
setup() {
const pdfStreamUrl = ref('');
async function fetchPdfStream() {
try {
let response = await fetch('/api/get-pdf-stream'); // 假设这是获取PDF二进制流的服务端接口地址
if (!response.ok) throw new Error('Network response was not ok');
// 将Blob对象转换成URL字符串形式
const blob = await response.blob();
pdfStreamUrl.value = URL.createObjectURL(blob);
} catch (error) {
console.error("Failed to load the PDF stream:", error);
}
}
onMounted(() => {
fetchPdfStream();
});
return {
pdfStreamUrl,
};
},
};
```
上述代码片段展示了如何创建一个异步函数用于请求服务器上的PDF资源,并将其作为blob类型的响应接收下来。之后利用JavaScript内置方法`URL.createObjectURL()`把接收到的数据转化为可以在浏览器环境中访问的对象URL,最后赋给模板中的变量以便渲染到页面上显示出来。
在HTML部分,则只需简单地绑定这个属性即可实现PDF展示功能:
```html
<template>
<div class="pdf-container">
<!-- 如果有有效的url则会自动尝试加载 -->
<PdfEmbed :source="pdfStreamUrl"/>
</div>
</template>
<style scoped>
.pdf-container{
width: 80%;
height: calc(100vh - 2rem); /* 调整大小适应视窗 */
}
</style>
```
此段落描述了怎样构建前端界面元素,包括设置样式使PDF查看器能够良好地适配不同尺寸屏幕下的布局需求。
阅读全文
相关推荐


















