最近在做后台管理类的系统,需要在web页面阅读pdf文件。发现一个很好用的插件 pdf.js
,简单的介绍一下
官方文档地址:http://mozilla.github.io/pdf.js/
在线演示地址:http://mozilla.github.com/pdf.js/web/viewer.html
介绍一下官网的例子
- 页面引入pdf.js
- 使用PDFJS.getDocument(‘helloworld.pdf’)方式加载要打开的PDF文件
- 通过Promise的then方式处理后续的方法
PDFJS.getDocument('helloworld.pdf')
.then(function(pdf){
//you can now use *pdf* here
});
pdf.getPage(1).then(function(page){
// you can now use *page* here
//;加载PDF的第一页
})
- 通过h5的canvas进行展示。
var scale = 1.5; //缩放比例
//获取窗口大小
var viewport = page.getViewport(scale);
//获取canvas对象
var canvas = document.getElementById('the-canvas');
var context = canvas.getContext('2d');
canvas.height = viewport.height;
canvas.width = viewport.width;
var renderContext = {
canvasContext: context,
viewport: viewport
};
page.render(renderContext);
下面完整的例子:
页面部分:
<h1>PDF.js Previous/Next example</h1>
<div>
<button id="prev">Previous</button>
<button id="next">Next</button>
<span>Page: <span id="page_num"></span> / <span id="page_count"></span></span>
</div>
<canvas id="the-canvas"></canvas>
js部分:
//引入pdf.js之后
var url = '//cdn.mozilla.net/pdfjs/helloworld.pdf';
//加载核心文件
PDFJS.workerSrc = '//mozilla.github.io/pdf.js/build/pdf.worker.js';
var loadingTask = PDFJS.getDocument(url);
loadingTask.promise.then(function(pdf) {
console.log('PDF loaded');
var pageNumber = 1;
pdf.getPage(pageNumber).then(function(page) {
console.log('Page loaded');
var scale = 1.5;
var viewport = page.getViewport(scale);
var canvas = document.getElementById('the-canvas');
var context = canvas.getContext('2d');
canvas.height = viewport.height;
canvas.width = viewport.width;
var renderContext = {
canvasContext: context,
viewport: viewport
};
var renderTask = page.render(renderContext);
renderTask.then(function () {
console.log('Page rendered');
});
});
}, function (reason) {
console.error(reason);
});
具体使用方式可以查阅官方文档,demo
写的很详细。