處理移動端pdf展現問題

npm install pdfjs-dist --save  //安裝
<canvas v-for="page in pdfList" :id="'the-canvas'+page" :key="page"></canvas>
<script>
import PDFJS from "pdfjs-dist";
import pdfjsLib from "pdfjs-dist";
export default {
data(){
return {
pdfDoc: null,
pdfList: 0
}
},
mounted() {
this.initThePDFJSLIB();
let url = ''
console.log(url);
this.loadFile(url);
},
methods: {
// 初始化pdfjs
initThePDFJSLIB() {
pdfjsLib.GlobalWorkerOptions.workerSrc = "pdfjs-dist/build/pdf.worker.js";
},
_renderPage(num) {
this.pdfDoc.getPage(num).then(page => {
let canvas = document.getElementById("the-canvas" + num);
let ctx = canvas.getContext("2d");
let dpr = window.devicePixelRatio || 1;
let bsr =
ctx.webkitBackingStorePixelRatio ||
ctx.mozBackingStorePixelRatio ||
ctx.msBackingStorePixelRatio ||
ctx.oBackingStorePixelRatio ||
ctx.backingStorePixelRatio ||
1;
let ratio = dpr / bsr;
let viewport = page.getViewport(
screen.availWidth / page.getViewport(1).width
);
canvas.width = viewport.width * ratio;
canvas.height = viewport.height * ratio;
canvas.style.width = viewport.width + "px";
canvas.style.height = viewport.height + "px";
ctx.setTransform(ratio, 0, 0, ratio, 0, 0);
let renderContext = {
canvasContext: ctx,
viewport: viewport
};
page.render(renderContext);
if (this.pdfList > num) {
this._renderPage(num + 1);
}
});
},
loadFile(base64Str) {
PDFJS.getDocument({data:  ///data對象能夠換成url
  atob(base64Str),
  cMapUrl: 'https://cdn.jsdelivr.net/npm/pdfjs-dist@2.0.943/cmaps/',
  cMapPacked: true
  }).then(pdf => {
  this.pdfDoc = pdf;
  this.pdfList = this.pdfDoc.numPages;
  this.$nextTick(() => {
  this._renderPage(1);
  });
});
}
},
components: {
}
};
</script>
<style lang="scss" scoped>
canvas {
display: block;
border-bottom: 1px solid black;
}
</style>
但最後由於電子簽章問題仍是換成圖片的base64了(電子簽章能夠處理出來但樣式亂了)
在build的pdf.worker.js中註釋下就好了
if (data.fieldType === 'Sig') {
data.fieldValue = null;

//_this2.setFlags(_util.AnnotationFlag.HIDDEN);
}
相關文章
相關標籤/搜索