如何在vue中使用pdfjs预览pdf文件

2022-04-15 0 778
目录
  • 前言
  • 思考
  • 库目录解析和下载
  • 使用方法
    • 文件位置
    • 实际调用
    • 问题
  • 总结

    前言

    在写项目的过程中,偶尔会有使用到pdf的文件,当我们想看pdf文件的时候,你的操作是不是先把pdf文件下载下来,通过电脑安装的专用于打开pdf的软件来查看pdf文件呢。如果有个需求说不要让用户安装软件呢,毕竟还是有很多用户不知道怎么安装软件或者这个东西需要什么东西才能打开嘛。ok,有了这样的需求那我们是不是也得去实现嘛,毕竟这理由咱也没法反驳啊。

    思考

    既然都提出来了,那就想想怎么使用咯。既然需要用到pdf。不知道有没有关于js能够操作的库文件来帮我呢?果断一百度,咱们今天的主角就来了:pdfjs。

    库目录解析和下载

    既然有了方案,那就去研究研究了,首先需要去下载这个库的文件,下载地址:点我下载。这个页面会有两个,一个是兼容旧版的,大家可以根据自己的实际情况下载啊。

    如何在vue中使用pdfjs预览pdf文件

    下载后的代码结构如下图:

    如何在vue中使用pdfjs预览pdf文件

    这里面有两个文件夹:

    • build 这里面是pdf核心文件
    • web 例子

    使用方法

    有两种使用方法,一种是通过核心库文件自己去实现pdf的预览,还有一种是通过给的例子去预览pdf文件。这里呢就以给的例子来预览pdf文件,如果大家有兴趣可以去研究研究怎么用核心文件去实现咯。

    文件位置

    首先我们需要将下载好的文件放到vue项目的static静态目录下,如下图:

    如何在vue中使用pdfjs预览pdf文件

    实际调用

    在需要用到的地方使用如下方式调用:

    var url = encodeURIComponent(window.location.origin+'/other/202101/dc88623a-74c4-49c4-bc95-7e34d9cf6163.pdf')
    window.open(window.location.origin + window.location.pathname+'static/pdfjs/web/viewer.html?file='+url)
    

    上面的pdf地址为自己放在本地的路径,这里路径可以为相对和绝对路径,上面为绝对路径

    这时就可以看到如下效果啦:

    如何在vue中使用pdfjs预览pdf文件

    问题

    如果这个pdf文件的地址和当前下载的库文件地址在相同的域下,应该不会有太大问题的,如果不同域下就需要解决跨域的问题了。这里有个地方需要解决就是我们下载的库文件,找到viewer.js文件中下面的内容注释:

    如何在vue中使用pdfjs预览pdf文件

    将上图中红色框框里面的内容注释。如果服务端给出的是下载地址,那么可以使用iframe嵌套来解决。

    总结

    其实可以看到跨域的知识有时候还是很有用的,上面就用到了,我刚开始弄的时候怎么都出不来,后面发现跨域下载不下来。当前还有更多的用法和问题,欢迎大家提出来。

    以上就是如何在vue中使用pdfjs预览pdf文件的详细内容,更多关于vue中使用pdfjs预览pdf文件的资料请关注NICE源码其它相关文章!

    免责声明:
    1、本网站所有发布的源码、软件和资料均为收集各大资源网站整理而来;仅限用于学习和研究目的,您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。 不得使用于非法商业用途,不得违反国家法律。否则后果自负!

    2、本站信息来自网络,版权争议与本站无关。一切关于该资源商业行为与www.niceym.com无关。
    如果您喜欢该程序,请支持正版源码、软件,购买注册,得到更好的正版服务。
    如有侵犯你版权的,请邮件与我们联系处理(邮箱:skknet@qq.com),本站将立即改正。

    NICE源码网 JavaScript 如何在vue中使用pdfjs预览pdf文件 https://www.niceym.com/28797.html