From ea5d9ab00ea70479ebf6e765c4f4965ba0553c02 Mon Sep 17 00:00:00 2001
From: lmj <3407000732@qq.com>
Date: Mon, 6 Jun 2022 18:56:44 +0800
Subject: [PATCH] =?UTF-8?q?=E6=A1=88=E4=BE=8Bpdf=E6=BB=9A=E5=8A=A8?=
=?UTF-8?q?=E5=8A=A0=E8=BD=BD?=
MIME-Version: 1.0
Content-Type: text/plain; charset=UTF-8
Content-Transfer-Encoding: 8bit
---
src/components/PdfPreview/view.vue | 76 +++++++++++++++++++++++++++---
1 file changed, 69 insertions(+), 7 deletions(-)
diff --git a/src/components/PdfPreview/view.vue b/src/components/PdfPreview/view.vue
index 1062f1d5..6f25b874 100644
--- a/src/components/PdfPreview/view.vue
+++ b/src/components/PdfPreview/view.vue
@@ -31,7 +31,7 @@
0 / 0
{{ currentPage }} / {{ pageCount }}
-->
- 加载更多
+ 加载更多
@@ -63,6 +63,9 @@ export default {
scale: 100, //放大系数
loadedRatio:0,// 加载进度
showProgress:true,
+ moreState:1,// 1 加载更多 2 加载中 3无数据
+ isscroll:false,
+ pdfpage:0,
};
},
mounted() {
@@ -70,6 +73,13 @@ export default {
if(this.filePath){
this.loadInitPdf(this.filePath);
}
+ window.addEventListener(
+ "scroll",
+ this.handleScroll
+ );
+ },
+ beforeDestroy(){
+ window.removeEventListener("scroll",this.handleScroll);
},
watch:{
filePath(newVal){
@@ -89,36 +99,88 @@ export default {
},
methods: {
loadProgress(e){
- console.log(e,'loadProgress');
+ console.log(e,'loadProgress');
},
loadedPageHandle(e){
- console.log(e,'loadedPageHandle');
+ console.log(e,'loadedPageHandle');
+ this.pdfpage = e;
+
},
loadPdfHandle(e){
- console.log(e,'loadPdfHandle');
+ console.log(e,'loadPdfHandle');
},
clickMore(){
if(this.totalPages>this.showPages){
- this.showPages++;
+ this.showPages++;
}
- },
+ this.isscroll = true;
+
+ },
//加载页面
loadInitPdf(url) {
+
if(url && url.indexOf('.pdf')>-1){
let loadingTask = pdf.createLoadingTask(url);
this.src=loadingTask;
+
loadingTask.promise.then((pdf) =>{
+ console.log(pdf)
this.totalPages=pdf.numPages;
+
+
if(pdf.numPages>this.initNum){
this.showPages = this.initNum;
- }else{
+
+ } else{
this.showPages =pdf.numPages;
+
}
+
+
}).catch((err) =>{
this.$message.error("加载内容失败,请联系管理员");
});
+
}
},
+
+ handleScroll() {
+ let el_anking = document.querySelector('#case-list-content');
+ let innerHeight = document.querySelector('#pdf-perView').clientHeight
+ let outerHeight = document.documentElement.clientHeight
+ let scrollTop = document.documentElement.scrollTop
+
+ if(this.isscroll){
+ this.showPages++;
+ this.debounce(this.loadInitPdf(),5000);
+
+ }
+ // console.log(this.pdfpage,'000')
+ // console.log(this.totalPages,this.pdfpage)
+ if(this.pdfpage >= this.totalPages){
+ this.isscroll = false
+ this.moreState = 3
+ // console.log('hcuewhf')
+ }
+ // if(scrollTop > 400) {
+ // document.querySelector('#articleAnking').style.cssText = "position: fixed;top: 0;width:242.5px";
+ // } else {
+ // document.querySelector('#articleAnking').style.cssText = "position: static";
+ // }
+ },
+
+
+ debounce(func, wait) {// 非立即执行
+ let timeout;
+ return function () {
+ let context = this;
+ let args = arguments;
+ if (timeout) clearTimeout(timeout);
+ timeout = setTimeout(() => {
+ func.apply(context, args)
+ }, wait);
+ }
+},
prePage(type) {
if (this.currentPage > 1) {
this.currentPage--;