jquery中pdf在页面的显示和导出

jquery中pdf在页面的显示和导出

  • [01 显示pdf](#01 显示pdf)
    • [01 .pdf结尾在线接口显示到页面 (pdf.js库怎么安装及使用):只显示一页](#01 .pdf结尾在线接口显示到页面 (pdf.js库怎么安装及使用):只显示一页)
    • [02 如何用PDF.JS显示整个PDF (而不仅仅是一页)?](#02 如何用PDF.JS显示整个PDF (而不仅仅是一页)?)
    • [03 jQuery实现在线预览PDF文件(通过a标签链接跳转):](#03 jQuery实现在线预览PDF文件(通过a标签链接跳转):)
  • [02 导出pdf](#02 导出pdf)

想要实现弹窗中显示pdf内容,并导出pdf.

01 显示pdf

第一,二个是通过pdf.js实现pdf在页面的显示,只不多第一个只显示一页,第二个可显示全部;第三个是通过jquery.media.js实现pdf在页面的显示

重点讲第二个!!

01 .pdf结尾在线接口显示到页面 (pdf.js库怎么安装及使用):只显示一页

参考:https://www.yisu.com/ask/45769732.html

这个只显示第一页,想要显示全部页面,需要循环加载

02 如何用PDF.JS显示整个PDF (而不仅仅是一页)?

PDFJS有一个成员变量numPages,所以你只需要遍历它们。

但是重要的是要记住,在pdf.js中获取页面是异步的,因此顺序将得不到保证。所以你需要用链子锁住它们。你可以这样做:

javascript 复制代码
var currPage = 1; //Pages are 1-based not 0-based
var numPages = 0;
var thePDF = null;

//This is where you start
PDFJS.getDocument(url).then(function(pdf) {

        //Set PDFJS global object (so we can easily access in our page functions
        thePDF = pdf;

        //How many pages it has
        numPages = pdf.numPages;

        //Start with first page
        pdf.getPage( 1 ).then( handlePages );
});



function handlePages(page)
{
    //This gives us the page's dimensions at full scale
    var viewport = page.getViewport( 1 );

    //We'll create a canvas for each page to draw it on
    var canvas = document.createElement( "canvas" );
    canvas.style.display = "block";
    var context = canvas.getContext('2d');
    canvas.height = viewport.height;
    canvas.width = viewport.width;

    //Draw it on the canvas
    page.render({canvasContext: context, viewport: viewport});

    //Add it to the web page
    document.body.appendChild( canvas );

    //Move to next page
    currPage++;
    if ( thePDF !== null && currPage <= numPages )
    {
        thePDF.getPage( currPage ).then( handlePages );
    }
}

参考:https://cloud.tencent.com/developer/ask/sof/251356

03 jQuery实现在线预览PDF文件(通过a标签链接跳转):

参考:

https://blog.csdn.net/angellee1988/article/details/121644256

02 导出pdf

参考:

jquery页面:

https://blog.csdn.net/hnn567/article/details/132356614

微信小程序:

https://blog.csdn.net/hnn567/article/details/132304552

相关推荐
phltxy40 分钟前
Vue3入门指南:从环境搭建到数据响应式,开启高效前端开发之旅
前端·javascript·vue.js
小飞大王66641 分钟前
CSS基础知识
前端·css
Charlie_lll43 分钟前
学习Three.js–风车星系
前端·three.js
代码游侠43 分钟前
学习笔记——Linux内核与嵌入式开发1
linux·运维·前端·arm开发·单片机·嵌入式硬件·学习
玩电脑的辣条哥1 小时前
幽灵回复AI已回复但前端不显示的排查与修复
前端·人工智能
石去皿1 小时前
轻量级 Web 应用 —— 把一堆图片按指定频率直接拼成视频,零特效、零依赖、零命令行
前端·音视频
星夜落月2 小时前
Web-Check部署全攻略:打造个人网站监控与分析中心
运维·前端·网络
冰暮流星2 小时前
javascript之双重循环
开发语言·前端·javascript
爱敲点代码的小哥2 小时前
C#视觉模板匹配与动态绘制实战(绘制和保存,加载tb块,处理vpp脚本的方式)
前端·javascript·信息可视化
南风知我意9572 小时前
【前端面试3】初中级难度
前端·javascript·面试