PDFJs 在線預覽插件



0.
A.到官網 https://mozilla.github.io/pdf.js/getting_started/#download 下載最新版本
B 部署到IIS 中訪問 pdf.js/web/viewer.html 查看效果

1. 后台返回pdf的base64字段,用pdf.js展示
https://www.jianshu.com/p/8fb76e21b05e

2. 在線查看PDF文件,pdf.js使用方法
https://www.cnblogs.com/zhanggf/p/8504317.html

3.官方實例
https://github.com/mozilla/pdf.js/tree/master/examples/learning

 

_______________________________________________________________________________________________

大部分都是關於引入pdf的路徑,然后在前端頁面展示出來的。關於base64編碼后的pdf文件很少。直接引入pdf文件路徑的方法,我就不介紹了,大家可以參考其他博客。我現在介紹一下,經過base64編碼后的pdf文件如何在前端頁面顯示出來。

需要的知識點:大家需要知道 Unit8Array和arrayBuffer

首先說一下Unit8Array:(具體可自己查一下MDN https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Uint8Array)

Uint8Array 數組類型表示一個8位無符號整型數組,創建時內容被初始化為0。創建完后,可以以對象的方式或使用數組下標索引的方式引用數組中的元素。

                 語法結構:Uint8Array(length);//創建初始化為0的,包含length個元素的無符號整型數組

                                   Uint8Array(typedArray);

                                    Uint8Array(object);

          Uint8Array(buffer [, byteOffset [, length]]);

ArrayBuffer:又稱類型化數組
  1. 數組里面可以放數字、字符串、布爾值以及對象和數組等,ArrayBuffer放0和1組成的二進制數據
  2. 數組放在堆中,ArrayBuffer則把數據放在棧中(所以取數據時后者快)
  3. ArrayBuffer初始化后固定大小,數組則可以自由增減。(准確的說,視圖才應該跟數組來比較這個特點)

測試通的 base64 >> PDF 操作

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>pdf的使用</title>
</head>
<body>
<div id="container">
<div id="pop"></div>
</div>
<script src="jquery-1.10.2.js"></script>
<script src="../build/pdf.js"></script>
<script src="../build/pdf.worker.js"></script>

<script>
/*將請求來的base64編碼的pdf文件,替換多余的空格和換行(為了兼容其他瀏覽器)
* 再使用瀏覽器自帶的atob()的方式解析
* */
/*轉化編碼格式*/
function converData(data) {
data = data.replace(/[\n\r]/g, '');
var raw = window.atob(data);
var rawLength = raw.length;
var array = new Uint8Array(new ArrayBuffer(rawLength));
for (var i = 0; i < rawLength; i++) {
array[i] = raw.charCodeAt(i)
}
return array
}

/*將解碼后的值傳給pdfjsLib.getDocument(),交給pdf.js處理*/
var loadtask=null;
function showPdfFile(data) {
var fileContent = converData(data);
$('#container').show();
$('#pop').empty();
loadtask=pdfjsLib.getDocument(fileContent);

loadtask.then(function getPdfHelloWorld(pdf) {
pages = pdf.numPages;
for (var i = 1; i < pdf.numPages; i++) {
var id = 'page-id' + i;
$('#pop').append('<canvas id="' + id + '"></canvas>');
showAll('', i, id);
}
})
}

function showAll(url, i, id) {
loadtask.promise.then(function getPdfHelloWorld(pdf) {
pdf.getPage(i).then(function getPageHelloWorld(page) {
var scale = 2.0,
viewport = page.getViewport(scale),
canvas = document.getElementById(id),
context = canvas.getContext('2d');
canvas.height = viewport.height;
canvas.width = viewport.width;
var renderContext = {
canvasContext: context,
viewport: viewport
}
page.render(renderContext);

})

})
}

dataParameters={};
$.ajax({
url: 'http://localhost:20737/wind.CloudFile.Web/Home/Base64',
type: "post",
dataType: "json",
data: dataParameters,
beforeSend: function () {
// addLoadingEle();
},
success: function (data) {
console.log( 'msg:'+ JSON.stringify(data));
showPdfFile(data.Data);
},
complete:function(data){
// removeLoadingEle();
},
error: function (a) {
console.log(a); 
}
});

</script>
</body>
</html>

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM