使用pdf.js显示pdf文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
<script type="text/javascript" src="build/pdf.min.js"></script>
<script type="text/javascript">
PDFJS.workerSrc = 'build/pdf.worker.min.js';
</script>
<script type="text/javascript">
$.fn.showPDF = function(pdfUrl, opt){
    var options = $.extend({
            scale: 1,
            pageNum: 1
        }, opt || {});
 
    this.each(function(){
        var pdfDoc,
            canvas = document.createElement('canvas'),
            ctx = canvas.getContext('2d');
        $(this).append(canvas);
 
        function renderPage(num) {
            pdfDoc.getPage(num).then(function (page) {
                var viewport;
                if( typeof(options.width) == 'number' ){
                    viewport = page.getViewport(1);
                    options.scale = options.width / viewport.width;
                }
                viewport = page.getViewport(options.scale);
                canvas.height = viewport.height;
                canvas.width = viewport.width;
                var renderContext = {
                    canvasContext: ctx,
                    viewport: viewport
                };
                page.render(renderContext).promise.then(function () {
                    if( $.isFunction(options.afterShow) ){
                        options.afterShow();
                    }
                });
            });
        }
 
        if( $.isFunction(options.beforeShow) ){
            options.beforeShow();
        }
 
        PDFJS.getDocument(pdfUrl).then(function (doc){
            pdfDoc = doc;
            renderPage(options.pageNum);
        });
    });
}
 
$(function(){
    $('.pdfView').showPDF('1.pdf', {width: $(window).width()});
});
</script>

  

PDF.js https://mozilla.github.io/pdf.js/

 

posted @   刘镇维  阅读(3180)  评论(0编辑  收藏  举报
编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· winform 绘制太阳,地球,月球 运作规律
· AI与.NET技术实操系列(五):向量存储与相似性搜索在 .NET 中的实现
· 超详细:普通电脑也行Windows部署deepseek R1训练数据并当服务器共享给他人
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示