自学内容网 自学内容网

VUE + pdfh5 实现pdf 预览,主要用来uniappH5实现嵌套预览PDF

1. 安装依赖

npm install pdfh5 

2. pdfh5 预览(移动端,h5)

npm install pdfh5 , (会报错,需要其他依赖,不能直接用提示的语句直接npm下载,依旧会报错,npm报错:These dependencies were not found:* canvas in ./node_modules/pdfh5/js/pdf.js* dommatrix/dist/d )

npm install canvas

 vue2 实例

  • vue 文件中 创建div 节点
  • <template>
      <div class="wrap">
        <div id="demo"></div>
      </div>
    </template>
  • js 中配置
  • <script>
    import Pdfh5 from "pdfh5";  // 这两个一定要引入
    import "pdfh5/css/pdfh5.css"; // 这两个一定要引入, 这个是在加载时,顶部会出来一个加载进度条和一些其他的样式
    export default {
      name: "openPdf",
      data() {
        return {
          pdfh5: null,
        };
      },
      mounted() {
        // ---------------------------- 方法一 -----------------------------
        this.pdfh5 = new Pdfh5("#demo", {
          pdfurl: "https://www.*********uanfu.pdf", // pdf 地址,请求的地址需要为线上的地址,测试的本地的地址是不可以的
          lazy: true, // 是否懒加载
          withCredentials: true,
          renderType: "svg",
          maxZoom: 3, //手势缩放最大倍数 默认3
          scrollEnable: true, //是否允许pdf滚动
          zoomEnable: true, //是否允许pdf手势缩放
        });
        // --------------------------- 方法二 ---------------------------
        //实例化
        this.pdfh5 = new Pdfh5("#demo", {
            pdfurl: "https://www**********anfu.pdf",
        });
        //监听完成事件
        this.pdfh5.on("complete", function (status, msg, time) {
            console.log("状态:" + status +",信息:" +msg +",耗时:" + time + "毫秒,总页数:" + this.totalNum);
        });
      },
    };
    </script>
     
    

    本人亲测用的方法二,方法一会控制台报错

  • Vue3 实例

  • import Pdfh5 from "pdfh5";
    import "pdfh5/css/pdfh5.css";
    
    const refPdf = ref(null);
    const LoadPdf = (url) => {
      const pdfh5 = new Pdfh5(refPdf.value, {
        pdfurl: url,
      });
      pdfh5.on("complete", (status, msg, time) => { });
    };
    
    const getDocById = (id) => {
      readPDF(id).then((res) => {
        if (res) {
          LoadPdf(window.URL.createObjectURL(new Blob([res])));
        }
      });
    }
    


原文地址:https://blog.csdn.net/weixin_54930261/article/details/145063284

免责声明:本站文章内容转载自网络资源,如本站内容侵犯了原著者的合法权益,可联系本站删除。更多内容请关注自学内容网(zxcms.com)!