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

vue3+vite在线预览pdf

效果图
在这里插入图片描述
代码

<template><div class="pdf-preview"><div class="pdf-wrap"><vue-pdf-embed :source="state.source" :style="scale" class="vue-pdf-embed" :page="state.pageNum" /></div><div class="page-tool"><div class="page-tool-item" @click="lastPage()">上一页</div><div class="page-tool-item" @click="nextPage()">下一页</div><div class="page-tool-item">{{state.pageNum}}/{{state.numPages}}</div><div class="page-tool-item" @click="pageZoomOut()">放大</div><div class="page-tool-item" @click="pageZoomIn()">缩小</div><div class="page-tool-item" @click="$emit('close')">关闭</div></div></div>
</template>
<script setup lang="ts">
import VuePdfEmbed from "vue-pdf-embed";
//import { createLoadingTask } from "vue3-pdfjs/esm/vue-pdf.js";
import * as pdfjsLib from "pdfjs-dist";
import { reactive, onMounted, computed } from "vue";const props = defineProps({pdfUrl: {type: String,required: true}
})const state = reactive({source: props.pdfUrl, //预览pdf文件地址pageNum: 1, //当前页面scale: 1, // 缩放比例numPages: 0, // 总页数
});
const scale = computed(() => `transform:scale(${state.scale})`)
function lastPage() {if (state.pageNum > 1) {state.pageNum -= 1;}
}
function nextPage() {if (state.pageNum < state.numPages) {state.pageNum += 1;}
}
function pageZoomOut() {if (state.scale < 2) {state.scale += 0.1;}
}
function pageZoomIn() {if (state.scale > 0.8) {state.scale -= 0.1;}
}
onMounted(() => {pdfjsLib.GlobalWorkerOptions.workerSrc = "./pdf.worker.js";const loadingTask = pdfjsLib.getDocument(state.source);loadingTask.promise.then((pdf) => {state.numPages = pdf.numPages;});
});</script>
<style lang="css" scoped>
.pdf-preview {position: fixed;height: 100vh;width: 100vw;padding: 20px 0;box-sizing: border-box;background-color: #e9e9e9;left: 0;top: 0;z-index: 99999999;overflow-y: auto;
}.pdf-wrap {overflow-y: auto;
}.vue-pdf-embed {text-align: center;width: 60vw;border: 1px solid #e5e5e5;margin: 0 auto;box-sizing: border-box;
}.page-tool {position: fixed;bottom: 35px;padding-left: 15px;padding-right: 15px;display: flex;align-items: center;background: rgb(66, 66, 66);border-radius: 19px;z-index: 100;cursor: pointer;margin-left: 50%;transform: translateX(-50%);
}.page-tool-item {padding: 8px 15px;padding-left: 10px;cursor: pointer;color: #fff !important;
}
</style>
http://www.lryc.cn/news/205216.html

相关文章:

  • Python深度学习实战-基于Sequential方法搭建BP神经网络实现分类任务(附源码和实现效果)
  • 【前端】Webpack5中Html和CSS的压缩打包
  • postman接收后端返回的文件流并自动下载
  • 谈谈Net-SNMP软件
  • 前端对普通数字数组排序示例
  • SQL server中:常见问题汇总(如:修改表时不允许修改表结构、将截断字符串或二进制数据等)
  • 无线通信中CSI的含义
  • 如何一键核实验证身份证的真伪?
  • 冒泡排序:了解原理与实现
  • springboot maven项目环境搭建idea
  • vue3检测是手机还是pc端,监测视图窗口变化
  • B - Magical Subsequence (CCPC2021哈尔滨)
  • Leetcode刷题详解——x的平方根
  • windows安装docker,解决require wsl 2问题
  • 建立复数类
  • docker部署prometheus+grafana服务器监控(三) - 配置grafana
  • 面试题:说一下加密后的数据如何进行模糊查询?
  • LeetCode75——Day15
  • Qwt开发环境搭建(保姆级教程)
  • 【供应链】仓储、物流、车辆管理
  • 从另外一个进程中读取数据
  • 【FPGA零基础学习之旅#17】搭建串口收发与储存双口RAM系统
  • 建立Line类
  • 10_集成学习方法:随机森林、Boosting
  • 工业通信网关常用的工业通信协议
  • 如何将音频与视频分离
  • 【antd】form表单为空校验失效 form.item.rules传入非所需的api属性时,引起为空自动验证失效问题
  • 数据可视化的常见工具
  • 不希望你的数据在云中?关闭iPhone或Mac上的iCloud
  • 10 个最佳免费 PDF 压缩工具软件