【问题标题】:using mozilla PDFJS how to show all pages not a single使用 Mozilla PDFJS 如何显示所有页面而不是一个
【发布时间】:2021-05-05 13:52:16
【问题描述】:

请帮忙,我尝试了很多解决方案来逐一显示所有页面,但我得到不同的错误, 所以现在我正在使用 pdfjs 的演示代码及其一页的工作,任何人都知道如何显示所有页面。

我尝试了这个解决方案,但对我不起作用 How to display whole PDF (not only one page) with PDF.JS?

// If absolute URL from the remote server is provided, configure the CORS
// header on that server.
var url = 'demo.pdf';

// Loaded via <script> tag, create shortcut to access PDF.js exports.
var pdfjsLib = window['pdfjs-dist/build/pdf'];

// The workerSrc property shall be specified.
pdfjsLib.GlobalWorkerOptions.workerSrc = '//mozilla.github.io/pdf.js/build/pdf.worker.js';

// Asynchronous download of PDF
var loadingTask = pdfjsLib.getDocument(url);
loadingTask.promise.then(function(pdf) {
  console.log('PDF loaded');
  
  // Fetch the first page
  var pageNumber = 1;
  pdf.getPage(pageNumber).then(function(page) {
    console.log('Page loaded');
    
    var scale = 1.5;
    var viewport = page.getViewport({scale: scale});

    // Prepare canvas using PDF page dimensions
    var canvas = document.getElementById('the-canvas');
    var context = canvas.getContext('2d');
    canvas.height = viewport.height;
    canvas.width = viewport.width;

    // Render PDF page into canvas context
    var renderContext = {
      canvasContext: context,
      viewport: viewport
    };
    var renderTask = page.render(renderContext);
    renderTask.promise.then(function () {
      console.log('Page rendered');
    });
  });
}, function (reason) {
  // PDF loading error
  console.error(reason);
});
<script src="//mozilla.github.io/pdf.js/build/pdf.js"></script>
<canvas id="the-canvas"></canvas>

【问题讨论】:

    标签: javascript html css pdf pdfjs


    【解决方案1】:

    function renderPDF(url, canvasContainer, options) {
    
        options = options || { scale: 1 };
            
        function renderPage(page) {
            var viewport = page.getViewport(options.scale);
            var wrapper = document.createElement("div");
            wrapper.className = "canvas-wrapper";
            var canvas = document.createElement('canvas');
            var ctx = canvas.getContext('2d');
            var renderContext = {
              canvasContext: ctx,
              viewport: viewport
            };
            
            canvas.height = viewport.height;
            canvas.width = viewport.width;
            wrapper.appendChild(canvas)
            canvasContainer.appendChild(wrapper);
            
            page.render(renderContext);
        }
        
        function renderPages(pdfDoc) {
            for(var num = 1; num <= pdfDoc.numPages; num++)
                pdfDoc.getPage(num).then(renderPage);
        }
    
        PDFJS.disableWorker = true;
        PDFJS.getDocument(url).then(renderPages);
    
    }   
    
    
    renderPDF('https://res.cloudinary.com/sivadass/image/upload/v1519136548/hr-sample-pdf.pdf', document.getElementById('holder'));
    #holder{
      background: #eee;
      padding: 32px 0 16px 0;
    }
    .canvas-wrapper{
      margin-bottom: 16px;
    }
    canvas{
      margin: 0 auto;
      display: block;
    }
    
    **I hope, it will help you!**
    <script src="https://cdn.jsdelivr.net/npm/pdfjs-dist@2.0.385/build/pdf.min.js"></script>
      <div id="holder"></div>

    【讨论】:

      猜你喜欢
      • 2019-09-28
      • 2015-04-03
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 2013-08-30
      • 1970-01-01
      • 1970-01-01
      • 2016-03-26
      相关资源
      最近更新 更多