pdfh5.js移动端展示预览打开pdf文件

pdfh5.js 基于pdf.js和jQuery,web/h5/移动端PDF预览手势缩放插件。
  1. 注意:本地绝对路径地址不能加载,跨域问题用代理或者服务端解决。
  2. svg模式渲染存在缺陷,只能渲染普通pdf,带签名、印章的可能会渲染不全,报错,pdf.js官方目前没有给出解决方案
  3. canvas模式本质是图片,默认进去的时候,图片在手机端被缩放,不是原分辨率,所以失真模糊。所以需要放大查看pdf

使用示例:(两种方法)

一、script标签引入方式(需下载本项目文件夹css/pdfh5.css、js内所有文件)
  1. 引入css
<link rel="stylesheet" href="css/pdfh5.css" />
  1. 创建div
<div id="demo"></div>
  1. 依次引入js(需引用本项目的js,不要引用官方的pdf.js,jquery可以引用其它版的)
<script src="js/pdf.js" type="text/javascript" charset="utf-8"></script>
<script src="js/pdf.worker.js" type="text/javascript" charset="utf-8"></script>
<script src="js/jquery-2.1.1.min.js" type="text/javascript" charset="utf-8"></script>
<script src="js/pdfh5.js" type="text/javascript" charset="utf-8"></script>
var pdfh5 = new Pdfh5('#demo', {
  pdfurl: "网络地址"
});
二、npm安装方式(适应于vue), react使用方法类似vue(example/react-test是react使用示例)
npm install pdfh5
<template>
  <div id="app">
    <div id="demo"></div>
  </div>
</template>
<script>
  import Pdfh5 from "pdfh5";
  export default {
    name: 'App',
    data() {
      return {
        pdfh5: null
    mounted() {
        //实例化
      this.pdfh5 = new Pdfh5("#demo", {
        pdfurl: "../../static/test.pdf"
      });
      //监听完成事件
      this.pdfh5.on("complete", function (status, msg, time) {
        console.log("状态:" + status + ",信息:" + msg + ",耗时:" + time + "毫秒,总页数:" + this.totalNum)
</script>
<style>
    @import "pdfh5/css/pdfh5.css";
    padding: 0;
    margin: 0;
    html,body,#app {
    width: 100%;
    height: 100%;
</style>

*注意:如果css引用报错的话,按下面的方式引用。

import Pdfh5 from "pdfh5";
import "pdfh5/css/pdfh5.css";

转载文章:https://www.cnblogs.com/newcxd/p/13878302.html

原文链接:https://www.cnblogs.com/newcxd/p/13878302.html pdfh5.js pdfh5.js基于pd​​f.js和jQuery,web / h5 /移动端PDF预览手势插件。 注意:本地绝对路径地址不能加载,跨域问题用代理或服务端解决。 svg模式渲染存在缺陷,只能渲染普通pdf,带签名,印章的可能会渲染不全,报错,pdf.js官方目前没有提供解决方案 canvas模式本质是图片,至少进去的时候,图片在手机端被缩放,不是原分辨率,所以失真模糊。所以需要放大查看pdf React 是vue使用示例,vue示例展示axios调用接口展示pdf,跨域代理,相对路径等方法 是React使用示例 2021.02.03更新:更新goto方法,增加b 来源:SegmentFault 思否作者:会鹏因项目开发需要在线展示 PDF文件,为解决 PDF文件 在浏览器打开后电子签章、电子签名等展示不全且部分浏览器兼容问题特利用pdf.js解决该问题;pdf.js框架为HTML5,无需任何本地支持,兼容性极好只要浏览器支持 HTML5 即可(据说 IE9 以上都是可以的);当时解决该问题探索时间比较长,其实也并没有想象的那么困难比较简单特此记录... 今天用pdfh5.js框架来实现手机上对pdf的访问。中间遇到了一个问题,就是无法打开路径有中文的pdf文件。一开始考虑到是否是url没有进行encode,但是试了后没有用。最终看了官方pdf.js的代码,发现pdfh5.js的script标签页的charset要用gb2312,设置以后果然好了。 <script src="../build/pdfh5.js" type="text/javascript" charset="gb2312"> <script> this.pdfSrc = pdf.createLoadingTask(this.pdfSrc); let CMAP_URL = "https://unpkg.com/pdfjs-dist@2.0.943/cmaps/"; this.pdfSrc = pdf.createLoadingTask({ url: this.$route.query.pathUrl, cMapUrl: CMAP_URL, cMapPacked: true, 场景之前项目也有过pdf在线显示的场景,详见下面的两篇无文字刚开始使用pdf.js,后来发现由于签章有加密算法,导致签章显示不出来。又迫于签章的重要性,后来不得不考虑别的方法,把pdf转换成图片来展示。以前使用pdf.js都是直接在网上找的现成的可以使用的文件,这次直接从官网来自己搞。 http://blog.csdn.net/gao36951/article/details/52216765 要说在工作中,大家最常接触的可能就是各类文件了。 尤其是在当前信息技术的影响下,办公倡导无纸化、电子化,很多文件都存储在计算机里,从内容和形式上给文件管理工作带来了便利,但也带来了一些安全方面的挑战。 3.如要再次打开文件,需在控制面板中打开文件夹”选项点击“查看”按钮,勾选“显示隐藏的文件文件夹和驱动器”即可。压缩文件设置密码 防止重要文件被别人误看,还有一个安全保障的方法,就是给文件上... 由于项目中需要支持移动设备在线浏览pdf,苹果还好,天生支持,但是安卓中就不行了,需要第三方组件的支持。这里就找到了pdf.js,由于pdf数据太多,开始的时候没法一一测试,所以随便测试打开了几篇没问题后就直接上线了。但是后面就悲剧了,偶然收到反馈,有些pdf无法正常浏览,此为写本文的原因。具体的现像查找问题过程一、用火狐(火狐解析pdf是用的pdf.js)来直接打开这篇pdf,发现居然是对的,那... 最后选择了 pdfh5.js 强烈点赞 详情链接https://www.gjtool.cn/articles/2019/09/04/1567571649102.html 这个ios 和Android下 都可以手势放大缩小,点击可以下载图片,反正我找到的 移动端效果最好的插件了,安卓再也不用操作如此复杂的去打开pdf touchpdf.js 基于pd......