angularjs 将PDFJs Viewer.html转换为div

guykilcj  于 2023-10-15  发布在  Angular
关注(0)|答案(4)|浏览(125)

有没有人知道pdf.js(http://mozilla.github.io/pdf.js/web/viewer.html)中的viewer.html是否可以放在<div>中?.
或者更好的是,转换为AngularJs指令(我知道Angular有几个pdfjs指令,但它们都没有viewer.html的质量)。

g6baxovj

g6baxovj1#

把你的pdf文件的src放在iframe中,像这样:

<div><iframe src="/pdfjs/viewer.html/{src of PDF file}" style="position: relative;   top: 0;  bottom: 0; left: 0;   width: 100%;   height: 700px;  border: 0"></iframe></div>

它可以帮助你

mfuanj7w

mfuanj7w2#

你完全可以把viewer.html放在<div>中。
the source开始,然后将<div id="outerContainer"> Package 起来
在您自己的<div>中,然后您可以根据自己的喜好设置样式:

<div id="myContainer">
    <div id="outerContainer">

      <div id="sidebarContainer"> 
      </div>  <!-- sidebarContainer -->

      <div id="mainContainer">
      </div> <!-- mainContainer -->

      <div id="overlayContainer" class="hidden">
      </div>  <!-- overlayContainer -->

    </div> <!-- outerContainer -->
</div>

请注意,使宽度小于约800px压扁工具栏项目。

mwecs4sa

mwecs4sa3#

下面的示例使用pdf.js提供的JavaScript API将pdf加载到div中。你也可以看到the fiddle

// If absolute URL from the remote server is provided, configure the CORS
// header on that server.
var url = '//cdn.mozilla.net/pdfjs/helloworld.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);

    // 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.then(function () {
      console.log('Page rendered');
    });
  });
}, function (reason) {
  // PDF loading error
  console.error(reason);
});
#the-canvas {
  border:1px solid black;
}
<script src="//mozilla.github.io/pdf.js/build/pdf.js"></script>

<h1>PDF.js 'Hello, world!' example</h1>
<div>
<canvas id="the-canvas"></canvas>
</div>
2j4z5cfb

2j4z5cfb4#

在iframe中使用viewer.html
1.从https://github.com/mozilla/pdf.js/releases下载最新的库
1.解压它。将整个pdfjs目录移动到项目的public目录中。
1.使用此代码:

<iframe
      src="/pdfjs/web/viewer.html?file=/path-to-the-file.pdf"
      :width="500px"
      :height="500px"
      frameborder="0"
    ></iframe>

相关问题