1. 程式人生 > >base64編碼後的pdf文件前端頁面展示--pdf.js的應用

base64編碼後的pdf文件前端頁面展示--pdf.js的應用

如何 neu end ctype 創建 obj 展示 文件 tle

最近在整理項目中用到的插件或者使用心得,感覺還是寫成博客,能加深新一層的理解。

我先說一下我的需求:由於java後臺編譯的文件流在手機端加載速度太慢,所以想著可以在前端解析,放在頁面展示給用戶。

所以,我需要後臺傳給我的是base64編碼的pdf文件。我們知道,單純靠base64解析pdf文件是解析不了的。所以需要引入另一個pdf解析文件--pdf.js

具體的使用方法大家可以看源碼:https://mozilla.github.io/pdf.js/

我試著按源碼一步一步的操作的,但發現將build文件夾整體引入,也沒有方法解決我的需求。最後,在項目中只引用了pdf.js和pdf.worker.js。引入方式和其他引入js文件一樣。

我將我自己的demo放在gitHub上了,有興趣的可以看一下。這裏,我先說一下我的理解。

看了很多關於pdf.js的博客,大部分都是關於引入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初始化後固定大小,數組則可以自由增減。(準確的說,視圖才應該跟數組來比較這個特點)

接下來,我貼一下代碼
<!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="../js/pdf.js"></script>
<script src="../js/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 Unit8Array(new ArrayBuffer(rawLength));
        for (var i = 0; i < rawLength; i++) {
            array[i] = raw.charCodeAt(i)
        }
        return array
    }

    /*將解碼後的值傳給PDFJS.getDocument(),交給pdf.js處理*/
    function showPdfFile(data) {
        var fileContent = converData(data);
        $(‘#container‘).show();
        $(‘#pop‘).empty();
        PDFJS.getDocument(fileContent).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(url, i, id)
            }
        })
    }

    function showAll(url, i, id) {
        PDFJS.getDocument().then(function getPdfHelloWorld(pdf) {
            pdf.getPage(page).then(function getPageHelloWorld(page) {
                var scale = 1.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)

            })

        })
    }

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

  


base64編碼後的pdf文件前端頁面展示--pdf.js的應用